> 데이터 베이스 > MySQL 튜토리얼 > SQL을 사용하여 취소되지 않은 예약을 찾는 방법: `NOT IN` 및 `LEFT JOIN`?

SQL을 사용하여 취소되지 않은 예약을 찾는 방법: `NOT IN` 및 `LEFT JOIN`?

Barbara Streisand
풀어 주다: 2025-01-23 19:42:11
원래의
772명이 탐색했습니다.

How to Find Uncancelled Reservations Using SQL: `NOT IN` vs. `LEFT JOIN`?

취소되지 않은 예약을 찾는 SQL 기법

이 기사에서는 reservationreservation_log 테이블이 있는 데이터베이스에서 취소되지 않은 예약을 검색하는 두 가지 효율적인 SQL 방법을 살펴봅니다. 취소기록이 없는 예약만 선별하는 것이 목표입니다.

방법 1: 하위 쿼리와 함께 NOT IN 사용

이 접근 방식은 하위 쿼리를 사용하여 reservation_log 테이블에 '취소'라는 change_type이 있는 예약 ID를 식별합니다. 그런 다음 기본 쿼리는 다음 목록에 ID가 없는 예약을 선택합니다.

<code class="language-sql">SELECT *
FROM reservation
WHERE id NOT IN (SELECT reservation_id
                 FROM reservation_log
                 WHERE change_type = 'cancel');</code>
로그인 후 복사

방법2: 활용LEFT JOIN

더 효율적인 대안은 LEFT JOIN을 사용하여 reservationreservation_log 테이블을 결합합니다. LEFT JOIN은 오른쪽 테이블(reservation)에 일치하는 항목이 없더라도 왼쪽 테이블(reservation_log)의 모든 행을 반환합니다. 일치하는 항목이 없으면 오른쪽 테이블의 열은 NULL이 됩니다. NULL 열에서 change_type 값을 필터링하면 취소되지 않은 예약이 분리됩니다.

<code class="language-sql">SELECT r.*
FROM reservation r
LEFT JOIN reservation_log l ON r.id = l.reservation_id AND l.change_type = 'cancel'
WHERE l.id IS NULL;</code>
로그인 후 복사

두 방법 모두 동일한 결과를 얻습니다. 그러나 LEFT JOIN 하위 쿼리와 관련된 잠재적인 성능 문제를 방지하므로 특히 대규모 데이터 세트의 경우 향상된 성능 때문에 NOT IN 접근 방식이 일반적으로 선호됩니다. 귀하의 데이터베이스 시스템과 데이터 볼륨에 가장 적합한 방법을 선택하세요.

위 내용은 SQL을 사용하여 취소되지 않은 예약을 찾는 방법: `NOT IN` 및 `LEFT JOIN`?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿