SQL-从一个表中查找另一个表中不存在的记录-问答-阿里云开发者社区-阿里云

开发者社区> 问答> 正文

SQL-从一个表中查找另一个表中不存在的记录

保持可爱mmm 2020-05-10 17:20:16 27

我有以下两个SQL表(在MySQL中):

Phone_book +----+------+--------------+ | id | name | phone_number | +----+------+--------------+ | 1 | John | 111111111111 | +----+------+--------------+ | 2 | Jane | 222222222222 | +----+------+--------------+

Call +----+------+--------------+ | id | date | phone_number | +----+------+--------------+ | 1 | 0945 | 111111111111 | +----+------+--------------+ | 2 | 0950 | 222222222222 | +----+------+--------------+ | 3 | 1045 | 333333333333 | +----+------+--------------+ 如何找出哪些电话是由人,他们提出phone_number是不是在Phone_book?所需的输出将是:

Call +----+------+--------------+ | id | date | phone_number | +----+------+--------------+ | 3 | 1045 | 333333333333 | +----+------+--------------+ 任何帮助将非常感激。

SQL 关系型数据库 MySQL
分享到
取消 提交回答
全部回答(1)
  • 保持可爱mmm
    2020-05-10 17:20:33

    有几种不同的方法可以执行此操作,效率各不相同,具体取决于查询优化器的性能以及两个表的相对大小:

    这是最简短的陈述,如果您的电话簿很短,则可能是最快的陈述:

    SELECT * FROM Call WHERE phone_number NOT IN (SELECT phone_number FROM Phone_book) 或者(由于Alterlife)

    SELECT * FROM Call WHERE NOT EXISTS (SELECT * FROM Phone_book WHERE Phone_book.phone_number = Call.phone_number) 或(感谢WOPR)

    SELECT * FROM Call LEFT OUTER JOIN Phone_Book ON (Call.phone_number = Phone_book.phone_number) WHERE Phone_book.phone_number IS NULL有几种不同的方法可以执行此操作,效率各不相同,具体取决于查询优化器的性能以及两个表的相对大小:

    这是最简短的陈述,如果您的电话簿很短,则可能是最快的陈述:

    SELECT * FROM Call WHERE phone_number NOT IN (SELECT phone_number FROM Phone_book) 或者(由于Alterlife)

    SELECT * FROM Call WHERE NOT EXISTS (SELECT * FROM Phone_book WHERE Phone_book.phone_number = Call.phone_number) 或(感谢WOPR)

    SELECT * FROM Call LEFT OUTER JOIN Phone_Book ON (Call.phone_number = Phone_book.phone_number) WHERE Phone_book.phone_number IS NULL来源:stack overflow

    0 0
数据库
使用钉钉扫一扫加入圈子
+ 订阅

分享数据库前沿,解构实战干货,推动数据库技术变革

推荐文章
相似问题