V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
laofan666
V2EX  ›  数据库

大家工作中增删改是(写 sql)还是(代码里单表增删改+事务)?

  •  
  •   laofan666 · 173 天前 · 1361 次点击
    这是一个创建于 173 天前的主题,其中的信息可能已经有所发展或是发生改变。

    最近遇到一个笔试题,通过一些子表的条件来删除主表数据,类似这种

    DELETE P
      FROM Product P
      LEFT JOIN OrderItem I ON P.Id = I.ProductId
     WHERE I.Id IS NULL
    

    工作中一直都是代码操作单表,然后加事务, 像上面这个 sql ,一般先查出 P 表 id 再根据 id 删除, 想知道 v 友们是什么情况?

    4 条回复    2024-07-03 16:53:53 +08:00
    lyusantu
        1
    lyusantu  
       172 天前
    这不是让你减少一次查询嘛
    正常来说的话 I 表的 ID 应是主键 也不存在为 null 的情况吧
    Nitsuya
        2
    Nitsuya  
       172 天前
    I 表会卡全表. 看业务和数据.
    onll42y
        3
    onll42y  
       172 天前
    这个 SQL 是说把没有产生过订单的商品全部删除,用代码单表查的话,实现费事一点,执行效率也没这个高
    andykuen959595
        4
    andykuen959595  
       172 天前
    这种也可以的,实在是不放心,可以先过滤出来,然后插入临时表,最后再删除。估计保险吧
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1103 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 19ms · UTC 18:01 · PVG 02:01 · LAX 10:01 · JFK 13:01
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.