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中添加的,就好像产生幻觉一样,这就是发生了幻读。
幻读和不可重复读都是读取了另一条已经提交的事务(这点就脏读不同),所不同的是不可重复读查询的都是同一个数据项,而幻读针对的是一批数据整体(比如数据的个数)。
事务隔离级别:
读未提交:事务未提交的数据可以读。什么问题都解决不了
读已提交:读取已经提交了的数据,可以防脏读,不能防不可重复读和幻读。
可重复读:读一个数据时,上锁。期间不让其他事务做删除修改操作
串行化:直到一个事务的所有子事务全部结束才可以执行下一个事务。