• 请不要在回答技术问题时复制粘贴 AI 生成的内容
rqxiao
V2EX  ›  程序员

sql not in 可以优化吗

  •  
  •   rqxiao · Mar 19, 2020 · 3457 views
    This topic created in 2254 days ago, the information mentioned may be changed or developed.

    DELETE FROM a WHERE a.mobile NOT IN ( SELECT DISTINCT mobile FROM b WHERE mobile IS NOT NULL )

    比如这样的一条 sql 逻辑 ,not in

    数据量很大 删了好久

    7 replies    2020-03-19 17:21:23 +08:00
    heaton_nobu
        1
    heaton_nobu  
       Mar 19, 2020
    1. NOT EXISTS
    2. LEFT JOIN
    ganbuliao
        2
    ganbuliao  
       Mar 19, 2020
    子查询当然慢了 和 not in 无关
    hammer86
        3
    hammer86  
       Mar 19, 2020 via iPhone
    not in 不走索引 所以慢
    sagaxu
        4
    sagaxu  
       Mar 19, 2020 via Android   ❤️ 1
    shangfabao
        5
    shangfabao  
       Mar 19, 2020
    left join * b
    where b.* is null
    alya
        6
    alya  
       Mar 19, 2020
    left semi join
    25OHd2qObJmJ6P10
        7
    25OHd2qObJmJ6P10  
       Mar 19, 2020
    IS NOT NULL 和 NOT IN 都不走索引,能不慢么,楼上都对
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   5501 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 56ms · UTC 06:44 · PVG 14:44 · LAX 23:44 · JFK 02:44
    ♥ Do have faith in what you're doing.