gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-11-29 16:31:16 24 4
gpt4 key购买 nike

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

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com