事务四大特性

事务的概念:事务是指逻辑上的一组操作,这组操作要么同时完成要么同时不完成.(举个例子,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)

原子性:原子性是指事务是一个不可分割的工作单位,事务中的操作要么都发生,要么都不发生。 

一致性:如果事务执行之前数据库是一个完整性的状态,那么事务结束后,无论事务是否执行成功,数据库仍然是一个完整性状态.(比如部门员工,你解散员工,没有删除了部门,有外键约束,最终部门还在,员工没了,违反了一致性。)

数据库的完整性状态:当一个数据库中的所有的数据都符合数据库中所定义的所有的约束(主键约束,非空约束,外键约束等),此时可以称数据库是一个完整性状态.

隔离性:事务的隔离性是指多个用户并发访问数据库时,一个用户的事务不能被其它用户的事务所干扰,多个并发事务之间数据要相互隔离。

持久性:持久性是指一个事务一旦被提交,它对数据库中数据的改变就是永久性的,接下来即使数据库发生故障也不应该对其有任何影响。(一旦提交了,就不可以执行回滚操作)




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值