在一个事务中对一个表操作步骤/顺序:
1、查询表的数据
2、插入新的数据
3、更新查询表的数据(这一步在执行更新sql语句,卡主,事务结束不了)
后面顺序修改(事务能结束):
1、查询表的数据
2、更新查询表的数据
3、插入新的数据
不同的数据库有不同的锁机制,保证数据库数据在不同的事务并发操作下的正确性的, 例如 ORACLE 就有行级锁 ,如果 对刚插入的一条数据 还没有执行提交操作就 继续执行更新操作的话 因为刚刚插入的数据还没有提交,被之前的事务执行了行级锁 锁住了这一行数据 所以会更新失败 , 你可以试试 提交了之前的事务 再去执行后面的事务是可以的
在对一个表进行update时,应该是不能查询的。所以该功能不能实现:同时查询一个表,还要同时update 只能分成两条,或是用存储过程来实现。
直接update就可以了,这样子写太过于频繁,会导致卡
意向锁与GAP锁或排它锁冲突
被锁了,更新动作的事务没提交