事务

Transaction:一组操作,包含多个单一的逻辑,只要有一个没有执行成功,那么回归到最初的状态(回滚)
命令行
start transaction;
sql语句
rollback或commit

//定义对象
		Connection conn =null;
		PreparedStatement ps = null;
		ResultSet rs = null;
		String sql = "select * from stu_user";
		try {
			conn = JDBCUtil.getConn();//获取链接
			conn.setAutoCommit(false);//关闭自动提交
			ps = conn.prepareStatement(sql);
			rs = ps.executeQuery();
			conn.commit();//提交事务
			}
		} catch (SQLException e) {
			try {
				conn.rollback();//回滚事务
			} catch (SQLException e1) {
				// TODO Auto-generated catch block
				e1.printStackTrace();
			}
			e.printStackTrace();
		} finally{
			
		}
事务的特性
原子性

事务包含的逻辑不可分割

一致性

事务执行前后数据的完整性

隔离性

事务在执行期间不应该受到其他事务的影响

持久性

事务执行成功,数据应该持久保存到磁盘上

事务的安全隐患
select @@tx_isolation查看当前的隔离级别

Read Uncommited读未提交
Read Commited读已提交
Repeatable Read重复读
Serializabie可串行化

不考虑隔离级别设置,会出现以下问题
1.读
1.1脏读
set session transaction isolation level read uncommited
一个事务会读取到另一个事务未提交的数据
1.2不可重读读
set session transaction isolation level read commited
当前事务在另一个事务提交前后的查询结果不一致
1.3可重复读
set session transaction isolation level repeatable read
一个事务不受另一个事务的影响
1.4幻读
set session transaction isolation level serializabie
只有当前事务结束之后,其他操作才可以执行
按效率划分(从高到低)
读未提交》读已提交》可重复读》可串行化
按拦截程度划分(从高到低)
可串行化》可重复读》读已提交》读未提交
2.写
2.1丢失更新(后一个事务提交时覆盖前一个事务修改的数据)
悲观锁(一定会丢失更新)
select * from user for update锁机制:排他锁
当一个事物修改时另一个事务只有等当前事务提交或者回滚之后才可以操作
乐观锁(一定不会丢失)
需要程序自己控制

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值