[sql] SQL-한 테이블에서 다른 테이블에 존재하지 않는 레코드 찾기

다음 두 가지 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 |
+----+------+--------------+

도움을 주시면 감사하겠습니다.



답변

쿼리 최적화 프로그램의 성능과 두 테이블의 상대 크기에 따라 다양한 효율성으로이를 수행하는 여러 가지 방법이 있습니다.

이것은 가장 짧은 진술이며 전화 번호부가 매우 짧은 경우 가장 빠를 수 있습니다.

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 Call.ID, Call.date, Call.phone_number 
FROM Call 
LEFT OUTER JOIN Phone_Book 
  ON (Call.phone_number=Phone_book.phone_number) 
  WHERE Phone_book.phone_number IS NULL

쿼리 최적화 프로그램이 마법을 발휘할 수 있도록 하위 쿼리를 제거해야합니다.

또한 누군가가 기본 테이블이나 뷰를 변경하면 비효율적 인 코드를 손상시킬 수 있으므로 “SELECT *”는 사용하지 마십시오.


답변

아래 코드는 더 큰 데이터 세트를 처리 할 때 위에 제시된 답변보다 약간 더 효율적입니다.

SELECT * FROM Call WHERE 
NOT EXISTS (SELECT 'x' FROM Phone_book where 
Phone_book.phone_number = Call.phone_number)


답변

SELECT DISTINCT Call.id 
FROM Call 
LEFT OUTER JOIN Phone_book USING (id) 
WHERE Phone_book.id IS NULL

Phone_book 테이블에서 누락 된 여분의 id를 반환합니다.


답변

나는 생각한다

SELECT CALL.* FROM CALL LEFT JOIN Phone_book ON 
CALL.id = Phone_book.id WHERE Phone_book.name IS NULL


답변

SELECT t1.ColumnID,
CASE 
    WHEN NOT EXISTS( SELECT t2.FieldText  
                     FROM Table t2 
                     WHERE t2.ColumnID = t1.ColumnID) 
    THEN t1.FieldText
    ELSE t2.FieldText
END FieldText       
FROM Table1 t1, Table2 t2


답변

SELECT name, phone_number FROM Call a
WHERE a.phone_number NOT IN (SELECT b.phone_number FROM Phone_book b)