u014401428
苍岭
2017-10-11 12:14
采纳率: 33.3%
浏览 5.5k

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

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

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

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

5条回答 默认 最新

  • u013278314
    懒惰的毛毛虫 2017-10-12 03:14
    已采纳

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

    点赞 评论
  • fengyun123987
    fengyun123987 2017-10-12 00:45

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

    点赞 评论
  • clongke
    clongke 2017-10-12 01:58

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

    点赞 评论
  • u014401428
    苍岭 2017-10-12 02:32

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

    点赞 评论
  • linruib
    linruib 2017-10-14 08:52

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

    点赞 评论

相关推荐