1. 为什么使用事务
例如在转账的情形下
drop table if exists accout;
create table accout(
id int primary key auto_increment,
name varchar(20) comment '账户名称',
money decimal(11,2) comment '金额'
);
update accout set money=money-300 where name = '张三';
update accout set money=money+300 where name = '李四';
张三的账户要向李四转300元. 如果在执行完第一行转账sql语句后,网络出现错误,张三的账户就会减少300元,而李四的账户也没有增加钱数. 故而我们使用事务来控制,保证以上两句SQL要么全部执行成功,要么全部执行失败。
2.事物的概念
数据库事务( transaction)是访问并可能操作各种数据项的一个数据库操作序列,这些操作要么全部执行,要么全部不执行,是一个不可分割的工作单位。事务由事务开始与事务结束之间执行的全部数据库操作组成。
3.事务的四大特性
原子性:原子性是指包含事务的操作要么全部执行成功,要么全部失败回滚。
一致性:一致性指事务在执行前后状态是一致的。
隔离性:一个事务所进行的修改在最终提交之前,对其他事务是不可见的。
持久性:数据一旦提交,其所作的修改将永久地保存到数据库中。
4.事务并发执行的问题
脏读:事务A更新了数据,但还没有提交,这时事务B读取到事务A更新后的数据,然后事务A回滚了,事务B读取到的数据就成为脏数据了。
不可重复读:事务A对数据进行多次读取,事务B在事务A多次读取的过程中执行了更新操作并提交了,导致事务A多次读取到的数据并不一致。
幻读:事务A在读取数据后,事务B向事务A读取的数据中插入了几条数据,事务A再次读取数据时发现多了几条数据,和之前读取的数据不一致。
丢失修改:事务A和事务B都对同一个数据进行修改,事务A先修改,事务B随后修改,事务B的修改覆盖了事务A的修改。
不可重复读与幻读的区别:在不可重复读中,发现数据不一致主要是数据被更新了。在幻读中,发现数据不一致主要是数据增多或者减少了。
5. 事务的使用
1.开启事务:start transaction; 2.执行多条SQL语句 3.回滚或提交:rollback/commit;(rollback 执行回滚, commit 执行确认操作)
|