事务
MySQL:每条语句都属于独立的事务,默认自动管理提交的。
如果要把多条语句当成一个整体,name就需要把多条语句放在一个事务里
在命令行:
开启事务:start tanscation
提交事务:commit
回滚事务:rollback
JDBC 控制事务语句
Connection.setAutoCommit(false);
Connection.rollback;
Connection.commit;
事务的特点
原子性,一致性,隔离性和持久性
- 原子性:事务是数据库的逻辑工作单位,事务中包含的个操作要么都完成,要么都不完成
- 一致性:事务的结果必须是使数据库从一个一致性状态变到另一个一致性的状态因此当数据库只包含成功事务提交的结果时,就说数据库处于一致性状态。如果数据库系统运行中发生故障,有些事务尚未完成就被迫中断,这些未完成事务对数据库所做的修改有一部分已写入物理数据库,这时数据库就处于一种不正确的状态,或者说不一致的状态。
- 隔离性:一个事务的执行不能被其他事物干扰。即一个事务的内部的操作及使用的数据对其它并发事务是隔离的,并发执行的各个事务之间不能相互干扰。
- 持久性:指一个事务一旦提交,它对数据库中的数据的改变就应该是永久性的。接下来的其它操作或故障不应该对其执行结果有任何影响。
- 脏读:一个线程中的事务读到了另一个线程中未提交的数据。
- 不可重复读:一个线程中的事务读到了另一个线程中已经提交的update的数据。
- 虚读(幻读):一个线程中的事务读到了另一个线程中已提交的insert的数据。
事务的隔级别
- read uncommitted :脏读,不可重复读,虚读都有可能发生
- read committed:避免脏读的发生。不可重复读,虚读有可能发生
- repeatable read:避免脏读,不可重复读的发生。虚读有可能发生
- serializable:避免脏读,不可重复读,虚读的发生