취소되지 않은 예약을 찾는 SQL 기법
이 기사에서는 reservation
및 reservation_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
을 사용하여 reservation
및 reservation_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 중국어 웹사이트의 기타 관련 기사를 참조하세요!