laofan666
V2EX  ›  数据库

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

  •  
  •   laofan666 · Jul 2, 2024 · 1941 views
    This topic created in 697 days ago, the information mentioned may be changed or developed.

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

    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 replies    2024-07-03 16:53:53 +08:00
    lyusantu
        1
    lyusantu  
       Jul 3, 2024
    这不是让你减少一次查询嘛
    正常来说的话 I 表的 ID 应是主键 也不存在为 null 的情况吧
    Nitsuya
        2
    Nitsuya  
       Jul 3, 2024
    I 表会卡全表. 看业务和数据.
    onll42y
        3
    onll42y  
       Jul 3, 2024
    这个 SQL 是说把没有产生过订单的商品全部删除,用代码单表查的话,实现费事一点,执行效率也没这个高
    andykuen959595
        4
    andykuen959595  
       Jul 3, 2024
    这种也可以的,实在是不放心,可以先过滤出来,然后插入临时表,最后再删除。估计保险吧
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   2887 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 39ms · UTC 08:41 · PVG 16:41 · LAX 01:41 · JFK 04:41
    ♥ Do have faith in what you're doing.