>데이터 베이스 >MySQL 튜토리얼 >MySQL에서 다중 테이블 쿼리를 수행하는 방법은 무엇입니까?

MySQL에서 다중 테이블 쿼리를 수행하는 방법은 무엇입니까?

WBOY
WBOY원래의
2023-07-30 17:03:321672검색

MySQL에서 다중 테이블 쿼리를 수행하는 방법은 무엇입니까?

데이터베이스 쿼리에서는 다중 테이블 쿼리가 일반적인 요구 사항입니다. 다중 테이블 쿼리를 통해 여러 테이블의 데이터를 연결하고 상관시켜 보다 정확하고 포괄적인 쿼리 결과를 얻을 수 있습니다. MySQL은 JOIN 문, 하위 쿼리, 통합 쿼리 사용을 포함하여 다중 테이블 쿼리를 수행하는 다양한 방법을 제공합니다. 이 기사에서는 코드 예제와 함께 MySQL에서 다중 테이블 쿼리를 수행하는 방법을 소개합니다.

  1. 다중 테이블 쿼리에 INNER JOIN 사용
    INNER JOIN은 두 개 이상의 테이블의 관련 필드를 연결하여 연결 조건을 충족하는 레코드를 반환하는 가장 일반적이고 일반적으로 사용되는 다중 테이블 쿼리 방법 중 하나입니다. 예는 다음과 같습니다.
SELECT 
    Orders.OrderID,
    Customers.CustomerName,
    Orders.OrderDate
FROM
    Orders
INNER JOIN
    Customers ON Orders.CustomerID = Customers.CustomerID;

위 쿼리는 연결 조건을 충족하는 Orders 테이블 및 Customers 테이블의 레코드를 반환합니다. 쿼리 결과에는 OrderID, CustomerName 및 OrderDate 필드가 포함됩니다.

  1. 다중 테이블 쿼리에 LEFT JOIN 사용
    LEFT JOIN은 또 다른 일반적인 다중 테이블 쿼리 방법으로 왼쪽 테이블(왼쪽 테이블)의 모든 레코드와 오른쪽 테이블(오른쪽 테이블)의 연결 조건을 충족하는 레코드를 결합합니다. 테이블). 오른쪽 테이블에 일치하는 레코드가 없으면 왼쪽 테이블의 해당 필드에 NULL이 표시됩니다. 다음은 예입니다.
SELECT 
    Customers.CustomerName,
    Orders.OrderID
FROM
    Customers
LEFT JOIN
    Orders ON Customers.CustomerID = Orders.CustomerID;

위 쿼리는 모든 Customers 테이블 레코드를 반환하고 연결 조건을 충족하는 Orders 테이블 레코드와 일치합니다. 쿼리 결과에는 CustomerName 및 OrderID 필드가 포함됩니다.

  1. 다중 테이블 쿼리에 RIGHT JOIN 사용
    RIGHT JOIN은 LEFT JOIN의 반대입니다. 오른쪽 테이블(오른쪽 테이블)의 모든 레코드와 조인 조건을 충족하는 왼쪽 테이블(왼쪽 테이블)의 레코드를 일치시킵니다. 왼쪽 테이블에 일치하는 레코드가 없으면 오른쪽 테이블의 해당 필드에 NULL이 표시됩니다. 다음은 예입니다.
SELECT 
    Orders.OrderID,
    Customers.CustomerName
FROM
    Orders
RIGHT JOIN
    Customers ON Orders.CustomerID = Customers.CustomerID;

위 쿼리는 모든 Orders 테이블 레코드를 반환하고 연결 조건을 충족하는 Customers 테이블 레코드와 일치합니다. 쿼리 결과에는 OrderID 및 CustomerName 필드가 포함됩니다.

  1. 다중 테이블 쿼리에 FULL OUTER JOIN 사용
    FULL OUTER JOIN은 LEFT JOIN과 RIGHT JOIN을 결합한 쿼리 방법으로 연결 조건을 만족하는 모든 레코드를 반환하고 조건을 충족하지 않는 레코드를 NULL로 표시합니다. 그러나 MySQL은 FULL OUTER JOIN을 직접 지원하지 않지만 UNION 연산자를 사용하면 유사한 효과를 얻을 수 있습니다. 다음은 예시입니다.
SELECT 
    Customers.CustomerName,
    Orders.OrderID
FROM
    Customers
LEFT JOIN
    Orders ON Customers.CustomerID = Orders.CustomerID
UNION
SELECT 
    Customers.CustomerName,
    Orders.OrderID
FROM
    Customers
RIGHT JOIN
    Orders ON Customers.CustomerID = Orders.CustomerID
WHERE
    Customers.CustomerID IS NULL;

위 쿼리는 연결 조건을 충족하는 모든 Customers 테이블 레코드와 Orders 테이블 레코드를 반환하고 조건을 충족하지 않는 레코드를 NULL로 표시합니다.

다중 테이블 쿼리는 데이터베이스 쿼리에서 중요한 기술 중 하나입니다. 연결 연산자와 조건을 합리적으로 사용하면 실제 필요에 따라 여러 테이블에 대해 관련 쿼리를 수행하고 정확하고 포괄적인 결과를 얻을 수 있습니다. 이 기사가 MySQL에서 다중 테이블 쿼리를 수행하는 방법을 이해하는 데 도움이 되기를 바랍니다.

위 내용은 MySQL에서 다중 테이블 쿼리를 수행하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.