> 데이터 베이스 > MySQL 튜토리얼 > 사용자 정보 검색을 위해 서로 다른 열에서 동일한 테이블을 여러 번 효율적으로 조인하는 방법은 무엇입니까?

사용자 정보 검색을 위해 서로 다른 열에서 동일한 테이블을 여러 번 효율적으로 조인하는 방법은 무엇입니까?

Linda Hamilton
풀어 주다: 2024-10-24 10:36:30
원래의
444명이 탐색했습니다.

How to Efficiently Join the Same Table Multiple Times on Different Columns for User Information Retrieval?

다양한 사용자 정보 검색을 위해 서로 다른 열에서 동일한 테이블을 두 번 조인

이 쿼리의 목표는 Open_by 및 Closed_by 열 모두에 대한 사용자 이름을 검색하는 것입니다. 사용자가 사용자 테이블에 저장되는 불만 사항 테이블에서. 문제는 서로 다른 열을 사용하여 사용자 테이블을 여러 번 조인하는 것입니다.

이 작업을 수행하기 위해 사용자 테이블의 각 인스턴스에 대해 LEFT JOIN 작업을 사용하고 명확성을 위해 조인된 테이블의 별칭을 A와 B로 지정합니다. 쿼리는 다음과 같이 진행됩니다.

SELECT 
     complaint.complaint_text, 
     A.username, 
     B.username
FROM 
     complaint 
     LEFT JOIN user A ON A.user_id=complaint.opened_by 
     LEFT JOIN user B ON B.user_id=complaint.closed_by
로그인 후 복사

이 쿼리에서는 불만 사항 테이블에서 informal_text 열을 선택하고,open_by 및closed_by 열 모두에 대한 user 테이블에서 사용자 이름을 선택하는 것으로 시작합니다.

그런 다음 LEFT JOIN을 사용하여 Open_by 열을 기반으로 불만 사항 테이블을 사용자 테이블과 조인합니다. 이를 통해 불만사항.opened_by의 user_id를 사용자 테이블의 user_id와 일치시키고 해당 사용자 이름을 검색할 수 있습니다. 조인된 테이블의 별칭을 A로 지정합니다.

다음으로, close_by 열을 기반으로 불만 사항 테이블과 사용자 테이블 사이에 또 ​​다른 LEFT JOIN 작업을 수행합니다. 이 조인된 테이블의 별칭을 B로 지정합니다.

이 쿼리의 결과는 불만 제기자 및 해결된 작성자 열의 사용자 이름과 함께 불만 사항 세부 정보를 명확하게 보여줍니다.

위 내용은 사용자 정보 검색을 위해 서로 다른 열에서 동일한 테이블을 여러 번 효율적으로 조인하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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