duanli9930 2011-03-13 03:41
浏览 18
已采纳

MySQL加入和排除?

I have two tables, table A one with two columns: IP and ID, and table B with columns: ID and extra information. I want to extract the rows in table B for IPs that are not in table A. So if I have a rows in table A with

id = 1
ip = 000.000.00
id = 2
ip = 111.111.11

and I have rows in table B

id = 1
id = 2

then, given ip = 111.111.11, how can I return row 1 in table B?

  • 写回答

2条回答 默认 最新

  • dtvnnhh8992 2011-03-13 03:46
    关注

    The simplest and most easy-to-read way to spell what you're describing is:

    SELECT * FROM `B` WHERE `ID` NOT IN (SELECT `ID` FROM `A`)
    

    You should be aware, though, that using a subquery for something like this has historically been slower than doing the same thing with a self-join, because it is easier to optimise the latter, which might look like this:

    SELECT
       `B`.*
    FROM
       `B`
    LEFT JOIN
       `A` ON `A`.`ID` = `B`.`ID`
    WHERE
       `A`.`ID` IS NULL
    

    However, technology is improving all the time, and the extent to which this is true (or even whether this is true) depends on the database software you're using.

    You should test both approaches then settle on the best balance of readability and performance for your use case.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥100 求用matlab求解上述微分方程的程序代码
  • ¥15 请问各位,如何在Jetson nano主控板的Ubuntu系统中安装PyQt5
  • ¥15 MAC安装佳能LBP2900驱动的网盘提取码
  • ¥400 微信停车小程序谁懂的来
  • ¥15 ATAC测序到底用什么peak文件做Diffbind差异分析
  • ¥15 安装ubantu过程中第一个vfat 文件挂载失败
  • ¥20 GZ::CTF如何兼容一些靶机?
  • ¥15 etcd集群部署问题
  • ¥20 谁可以帮我一下问一下各位
  • ¥15 为何重叠加权后love图的SMD与svyCreateTableOne函数绘制基线表的不一致