苍岭 2017-10-11 12:14 采纳率: 33.3%
浏览 5719
已采纳

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

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

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

  • 写回答

5条回答 默认 最新

  • 懒惰的毛毛虫 2017-10-12 03:14
    关注

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

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(4条)

报告相同问题?