百分百源码网-让建站变得如此简单! 登录 注册 签到领金币!

主页 | 如何升级VIP | TAG标签

当前位置: 主页>网站教程>数据库> 详解MySQL数据库之事务及存储引擎
分享文章到:

详解MySQL数据库之事务及存储引擎

发布时间:09/01 来源:未知 浏览: 关键词:

一、关系型数据库与非关系型数据库

1、关系型数据库的特点:

1)数据以表格的情势显现

2)每行动各种记载名称

3)每列为记载名称所对应的数据域

4)很多的行和列组成一张表单

5)若干的表单组成数据库

2、关系型数据库的优势:

1)复杂的查询:可以使用SQL语句利便地在一个表乃至多个表之间做非常复杂的数据查询。

2)事务支撑:使得关于平安机能很高的数据拜访要求得以实现。

3、非关系型数据库的优势:

1)机能:NOSQL是基于键值对的,可以想象成表中的主键和值的对应关系,并且不需要经过SQL层的解析,所以机能非常高。

2)可扩展性:一样也是由于基于键值对,数据之间没有耦合性,所以非常容易水平扩展。

问题:三种传统数据库之间的不同?

答:三者之间是按照数据之间的联络而去别的,层次性数据库是树形构造、网状型数据库是链接指针构造、关系型数据库是二维表构造。

二、事务(ACID)

事务(transaction)是作为单个逻辑工作单元施行的一系列操纵,这些操纵作为一个团体一起向系统提交,要末都施行,要末都不施行。事务是一个不成分割的工作逻辑单元。

事务必需具备以下四个属性,简称ACID属性:

原子性(atomicity):事务是一个完全的操纵。事物的各部操纵是不成分的(原子的);要末都施行,要末都不施行;

一致性(consistency):当事务完成时,数据必需处于一致状态;

隔离性(isolation):对数据停止修改的所有并发事务是彼此隔离的,这表白事务必需是独立的,它不该以任何情势依靠于或影响其他事务;

永远性(durability):事务完成后,它对数据库的修改是永远的,事务日志能够保持事务的永远性。

事务的隔离级别:

读取未提交内容(又称为脏读 read uncommitted):指所有事务都可以看到其他未提交事务的施行结果。大概有脏读、不成反复读和幻读问题。

读取提交内容(read commited):一个事务只能看见已经提交的事务所做的改动。可以幸免脏读,大概有不成反复读和幻读问题。

可反复读(repeatable read):是MySQL的默许事务隔离级别,它确保统一事务的多个实例在并发读取数据时,会看到一样的数据行。可以幸免脏读和不成反复读,大概会有幻读问题。

可串行化(serializable):是最高的隔离级别,它通过在每个读的数据行上加上同享锁,使之不成能彼此冲突,从而解决幻读问题。可以幸免脏读、不成反复读、幻读。

并发事务带来的问题:

1.更新丧失:两个事务T1和T2读入了统一数据并修改,T2提交的结果覆盖了T1提交的结果,致使T1的修改被丧失。

2.脏读:事务T1修改了某一数据,并将其写回磁盘,事务T2读取统一数据后,T1由于某种缘由被撤销,这时T1已修改正的数据复原原值,T2读到的数据就与数据库中的数据不一致,则T2读到的数据就为“脏”数据,即不准确的数据。

3.不成反复读:是指在一个事务内,屡次读统一数据。在这个事务还没有完毕时,别的一个事务也拜访了该统一数据。那么,在第一个事务中的两次读数据之间,由于第二个事务的修改,那么第一个事务两次读到的数据大概是不一样的。这就发生了在一个事务内两次雷同的查询读到的数据是不一样的,因此称为是不成反复读。

4.幻读:例如:当前薪水为5000的员工有10人,事务A读取所有薪水为5000的人数为10人。此时,事务B插入了一条薪水也为5000的记载。这时,事务A再次读取薪水为5000的员工,记载为11人。此时就发生了幻读。

不成反复读和幻读的不同?不成反复读的重点是修改,幻读的重点在于新增或删除。

MVCC(多版本并发操纵机制):InnoDB的MVCC,是通过在每行记载后面留存两个潜藏的列来实现的。离别留存了行的创立时间和行的删除时间(这里储备的并不是实际的时间值,而是系统版本号)。每开端一个新的事务,系统版本号都会主动递增。事务开端时刻的系统版本号会作为事务的ID,用来和查询到的每行记载的版本号停止比力,使用MVCC后可反复读隔离级别下不会显现幻读现象。

三、储备引擎

储备引擎是数据库底层软件组织,数据库治理系统(DBMS)使用数据引擎停止创立、查询、更新和删除数据。

1、InnoDB(汇集索引方式)

innodb底层储备构造为B+树,树的每个节点对应innodb的一个page,page的大小是牢固的,一样设为16K.其中非叶子节点只要键值,叶子节点包括完全数据。

使用处景:1)经常更新的表,是和处置多重并发的更新恳求;

2)支撑事务平安表(ACID),支撑行锁和外键;

3)可以通过bin-log日志等复原

innodb假如没有设定主键,就会主动生成一个6字节的主键(会员不成见)。

2、MyISAM(非聚簇索引方式)

MyISAM在5.1此前是MySQL的默许储备引擎,它强调的是机能,但是它不支撑事务、也不支撑行锁和外键,支撑表锁;当插入或更新数据时,需要锁住整个表,效力便会低一些。只缓存索引,不缓存真实数据。MyISAM读取数据时速度很快,并且不占用大量的内存和储备资源。

MyISAM同意没有主键的存在,是一种静态索引构造。

问题:MySQL中MyISAM与InnoDB的不同?

答:MySQL数据库中,最常用的两种引擎是innodb和myisam。InnoDB是当前MySQL的默许储备引擎。

1)事务方面:MyISAM强调的是机能,查询速度比InnoDB类型更快,但是不支撑事务。InnoDB供给事务支撑。

2)外键:MyISAM不支撑外键,InnoDB支撑外键。

3)锁:MyISAM只支撑表级锁,InnoDB支撑行级锁和表级锁,默许为行级锁,行锁大幅度提高了多会员并发操纵的机能。innodb比力适合于插入和更新操纵比力多的状况,而myisam则适合于频繁查询的状况。别的,innodb表的行锁也不是绝对的,假如在施行一个SQL语句时,MySQL不克不及肯定要扫描的范畴,innodb一样会锁全表,例如:update table set num=1 where name like "%aaa%"。

4)全文索引:MyISAM支撑全文索引,Innodb不支撑全文索引。innodb从MySQL5.6之后供给全文索引的支撑。

5)表主键:myisam同意没有主键的表存在;innodb:假如没有设定主键,就会主动生成一个6字节的主键(会员不成见)。

6)表的详细行数:myisam:select count(*) from table,myisam只要简便的读出留存好的行数。由于myisam内置了一个计数器,count(*)时它直接从计数器中读。

innodb:不留存表的详细行数,也就是说,施行select count(*) from table 时,innodb要扫描一遍整个表来运算有多少行。

引荐学习:MySQL教程

以上就是详解MySQL数据库之事务及储备引擎的具体内容,更多请关注百分百源码网其它相关文章!

打赏

打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

百分百源码网 建议打赏1~10元,土豪随意,感谢您的阅读!

共有155人阅读,期待你的评论!发表评论
昵称: 网址: 验证码: 点击我更换图片
最新评论

本文标签

广告赞助

能出一分力是一分吧!

订阅获得更多模板

本文标签

广告赞助

订阅获得更多模板