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