sql - 查找一个表中不存在于另一表中的记录

标签 sql mysql

我有以下两个表(在 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 |
+----+------+--------------+

最佳答案

有几种不同的方法可以实现此目的,其效率也各不相同,具体取决于您的查询优化器的性能以及两个表的相对大小:

这是最短的语句,如果您的电话簿很短,则可能是最快的:

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

(忽略这一点,正如其他人所说,通常最好只选择您想要的列,而不是“*”)

关于sql - 查找一个表中不存在于另一表中的记录,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53863499/

相关文章:

MYSQL如何查找包含10个以上数字的条目?

mysql - 创建统计数字的 MySQL 过程的正确方法是什么?

mysql - 列出mysql中所有表的序列号

sql - 插入、更新和删除后的版本查询输出

mysql - 检索 INSERT 的第 N 个子查询

mysql - MariaDB/MySQL 跨表连接时是否缓存键值关系?

java - 无法在 SQL 中更新给定字段

php - 错误 SET SQL_BIG_SELECTS=1 或 SET MAX_JOIN_SIZE=#

sql - 甲骨文 : Dynamic column name

mysql - 计算查询中的总项目数