事务的概念:事务是指逻辑上的一组操作,这组操作要么同时完成要么同时不完成.(举个例子,A给B转账,转100元。A账户减去100,B账户加上100。要么全部转账成功,要么失败,不可能一方转账了,一方没有收到)
事务的管理:默认情况下,数据库会自动管理事务,管理的方式是一条语句就独占一个事务.(一条SQL语句后,就会自动提交)
如果需要自己控制事务也可以通过如下命令开启/提交/回滚事务:starttransaction;开启事务, commit;提交事务, rollback;回滚事务。
JDBC中管理事务:
conn.setAutoCommit(false);
conn.commit();
conn.rollback();
SavePoint sp = conn.setSavePoint();设置事务回滚点,如果回滚点为null,说明没有执行到设置回滚点代码时就抛了异常,应该所有语句进行回滚。如果回滚点不为null,可以回滚到回滚点,接着执行其他操作,如果希望回滚点之前的语句起作用,仍然要将回滚点之前的语句提交。
conn.rollback(sp);
事务的四大特性:一个事务具有的最基本的特性,一个设计良好的数据库可以帮我们保证事务具有这四大特性(ACID)
原子性:原子性是指事务是一个不可分割的工作单位,事务中的操作要么都发生,要么都不发生。
一致性:如果事务执行之前数据库是一个完整性的状态,那么事务结束后,无论事务是否执行成功,数据库仍然是一个完整性状态.(比如部门员工,你解散员工,没有删除了部门,有外键约束,最终部门还在,员工没了,违反了一致性。)
数据库的完整性状态:当一个数据库中的所有的数据都符合数据库中所定义的所有的约束(主键约束,非空约束,外键约束等),此时可以称数据库是一个完整性状态.
隔离性:事务的隔离性是指多个用户并发访问数据库时,一个用户的事务不能被其它用户的事务所干扰,多个并发事务之间数据要相互隔离。
持久性:持久性是指一个事务一旦被提交,它对数据库中数据的改变就是永久性的,接下来即使数据库发生故障也不应该对其有任何影响。(一旦提交了,就不可以执行回滚操作)