MySQL事务

事务

MySQL:每条语句都属于独立的事务,默认自动管理提交的。
如果要把多条语句当成一个整体,name就需要把多条语句放在一个事务里

在命令行:

开启事务:start tanscation

提交事务:commit

回滚事务:rollback


JDBC 控制事务语句

Connection.setAutoCommit(false);

Connection.rollback;

Connection.commit;


事务的特点

原子性,一致性,隔离性和持久性

  • 原子性:事务是数据库的逻辑工作单位,事务中包含的个操作要么都完成,要么都不完成
  • 一致性:事务的结果必须是使数据库从一个一致性状态变到另一个一致性的状态因此当数据库只包含成功事务提交的结果时,就说数据库处于一致性状态。如果数据库系统运行中发生故障,有些事务尚未完成就被迫中断,这些未完成事务对数据库所做的修改有一部分已写入物理数据库,这时数据库就处于一种不正确的状态,或者说不一致的状态。
  • 隔离性:一个事务的执行不能被其他事物干扰。即一个事务的内部的操作及使用的数据对其它并发事务是隔离的,并发执行的各个事务之间不能相互干扰。
  • 持久性:指一个事务一旦提交,它对数据库中的数据的改变就应该是永久性的。接下来的其它操作或故障不应该对其执行结果有任何影响。

  • 脏读:一个线程中的事务读到了另一个线程中未提交的数据。
  • 不可重复读:一个线程中的事务读到了另一个线程中已经提交的update的数据。
  • 虚读(幻读):一个线程中的事务读到了另一个线程中已提交的insert的数据。

事务的隔级别

  • read uncommitted :脏读,不可重复读,虚读都有可能发生
  • read committed:避免脏读的发生。不可重复读,虚读有可能发生
  • repeatable read:避免脏读,不可重复读的发生。虚读有可能发生
  • serializable:避免脏读,不可重复读,虚读的发生

转载于:https://www.cnblogs.com/cqzy/p/11313120.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值