数据库先查询再插入最后更新查询数据问题?最后一步更新sql语句执行不下去?

在一个事务中对一个表操作步骤/顺序:
1、查询表的数据
2、插入新的数据
3、更新查询表的数据(这一步在执行更新sql语句,卡主,事务结束不了)
后面顺序修改(事务能结束):

1、查询表的数据
2、更新查询表的数据
3、插入新的数据

不同的数据库有不同的锁机制,保证数据库数据在不同的事务并发操作下的正确性的, 例如 ORACLE 就有行级锁 ,如果 对刚插入的一条数据 还没有执行提交操作就 继续执行更新操作的话 因为刚刚插入的数据还没有提交,被之前的事务执行了行级锁 锁住了这一行数据 所以会更新失败 , 你可以试试 提交了之前的事务 再去执行后面的事务是可以的

在对一个表进行update时,应该是不能查询的。所以该功能不能实现:同时查询一个表,还要同时update 只能分成两条,或是用存储过程来实现。

直接update就可以了,这样子写太过于频繁,会导致卡

意向锁与GAP锁或排它锁冲突

被锁了,更新动作的事务没提交