V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
rower
V2EX  ›  问与答

mysql 事务的处理,想问下这种情况下需要使用事务吗

  •  
  •   rower · 2022-06-30 10:48:15 +08:00 · 1058 次点击
    这是一个创建于 909 天前的主题,其中的信息可能已经有所发展或是发生改变。
    一个接口,涉及到两个表,两条 sql 。就是把这条数据从一个表删除,然后把数据插入到另一个表。

    新加一个字段,标记为是否删除这种情况不考虑啊!
    新加一个字段,标记为是否删除这种情况不考虑啊!
    新加一个字段,标记为是否删除这种情况不考虑啊!

    我想了下,只有当这个接口处理失败,比如说只删除数据,没有插入数据才会有问题。
    当并发时,如果这个接口执行到一半,其他人查询表,虽然结果不准确,但是只要接口成功,那么结果最终会准确。
    如果不是那种金融场景的话,这里可以容忍
    7 条回复    2022-06-30 13:37:55 +08:00
    aitaii
        1
    aitaii  
       2022-06-30 10:56:33 +08:00
    有一个 low 的方案,用触发器
    yuancoder
        2
    yuancoder  
       2022-06-30 11:06:58 +08:00
    hidemyself
        3
    hidemyself  
       2022-06-30 11:15:43 +08:00
    需要事务
    rower
        4
    rower  
    OP
       2022-06-30 11:17:37 +08:00
    @yuancoder
    @hidemyself
    为啥呢
    BeautifulSoap
        5
    BeautifulSoap  
       2022-06-30 11:19:02 +08:00   ❤️ 1
    按理说是要的,但如果你不想用事物的话,为什么不反过来先把数据插入另一个表,然后再从原始表把数据删除?
    按照 lz 的意思,反正数据插入另一个表没问题吧
    themostlazyman
        6
    themostlazyman  
       2022-06-30 11:20:26 +08:00
    为啥不需要呀,出问题给自己找麻烦。实在不想加建议先插入到另外一张表,再删除。
    akira
        7
    akira  
       2022-06-30 13:37:55 +08:00
    删除标记就是最优解
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   5367 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 07:49 · PVG 15:49 · LAX 23:49 · JFK 02:49
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.