温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

数据库ACID原则和事务隔离级别

发布时间:2020-06-30 20:31:44 来源:网络 阅读:1568 作者:arthur376 栏目:数据库
数据库ACID原则
A:原子性,Atomicity
C:一致性,Consistency
I:隔离性,Isolation
D:持久性,Durability
mysql中的innodb引擎,原子性,一致性,隔离性通过redo和undo实现,redo就是ib_logfile物理文件,而undo默认在共享表空间ibdata里面,通过设置参数可以独立出来.

事务隔离级别
Read Uncommitted(读未提交):    事务在执行过程中可以看到其他事务没有提交的插入和更改的数据,缺点是允许脏读,不允许同时进行写操作,但允许其他事务读没有提交的数据,对查询的准确性有很大的问题。
Read Committed(读已提交):    事务在执行过程中可以看到其他事务已经提交的新插入的记录,而且能看到其他事务已经提交的对已有记录的更新,即有可能存在重复查询同一记录会有不同结果的情况,但是确实是已经提交过的数据,缺点是允许幻读(之前不存在,但后来已提交的数据),不允许同时进行写操作,只允许读已提交的数据,但允许不可重复读(两次读的数据允许不一致),oracle和sqlserver的默认隔离级别.
Repeatable Read(可重复读):    事务在执行过程中可以看到其他事务已经提交的新插入的记录,但是不能看到其他其他事务对已有记录的更新,即重复查询同一记录是保持一致的,禁止不可重复读取和脏读,但在极端情况下还会有幻读,总体符合ACID原则,mysql默认的隔离级别.
Serializable(串行化):    事务串行化执行,事务只能一个接着一个地执行,并且在执行过程中完全看不到其他事务对数据库所做的更新,缺点是并发能力差,最严格的事务隔离,完全符合ACID原则,但是对性能影响比较大。
向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI