数据库事务的4大特性以及不考虑隔离产生的安全性问题

1.4大特性acid:

a:原子性:事务里的内容要么全部成功要么都不成功。

c:一致性:事务前后数据的完整性保持一致,如:a给b转一千块,事务执行以后,a和b的钱总数是一样的。

i:隔离性:隔离性是当多个用户并发访问数据库时,比如操作同一张表时,数据库为每一个用户开启的事务,不能被其他事务的操作所干扰,多个并发事务之间要相互隔离。

  即要达到这么一种效果:对于任意两个并发的事务T1和T2,在事务T1看来,T2要么在T1开始之前就已经结束,要么在T1结束之后才开始,这样每个事务都感觉不到有其他事务在并发地执行。

d:持久性:事务结束,数据就持久化到数据库。

 

安全性问题(不隔离导致):

脏读:一个事务读到另一个事务未提交的数据。

如:转账问题:a转b100;首先执行b+100;这是另一个事务读取b的钱多了100,但是只要原来的事务不提交,b就会回滚,这就是脏读。

不可重复读:在一个事务里面读取了两次某个数据,读出来的数据不一致

不可重复读是指在对于数据库中的某个数据,一个事务范围内多次查询却返回了不同的数据值,这是由于在查询间隔,被另一个事务修改并提交了。

  例如事务T1在读取某一数据,而事务T2立马修改了这个数据并且提交事务给数据库,事务T1再次读取该数据就得到了不同的结果,发送了不可重复读。

  不可重复读和脏读的区别是,脏读是某一事务读取了另一个事务未提交的脏数据,而不可重复读则是读取了前一事务提交的数据。

幻读:在一个事务里面的操作中发现了未被操作的数据

幻读是事务非独立执行时发生的一种现象。例如事务T1对一个表中所有的行的某个数据项做了从“1”修改为“2”的操作,这时事务T2又对这个表中插入了一行数据项,而这个数据项的数值还是为“1”并且提交给数据库。而操作事务T1的用户如果再查看刚刚修改的数据,会发现还有一行没有修改,其实这行是从事务T2中添加的,就好像产生幻觉一样,这就是发生了幻读。

  幻读和不可重复读都是读取了另一条已经提交的事务(这点就脏读不同),所不同的是不可重复读查询的都是同一个数据项,而幻读针对的是一批数据整体(比如数据的个数)。

 

事务隔离级别:

读未提交:事务未提交的数据可以读。什么问题都解决不了

读已提交:读取已经提交了的数据,可以防脏读,不能防不可重复读和幻读。

可重复读:读一个数据时,上锁。期间不让其他事务做删除修改操作

串行化:直到一个事务的所有子事务全部结束才可以执行下一个事务。

 

 

https://www.cnblogs.com/fjdingsd/p/5273008.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值