집 >데이터 베이스 >MySQL 튜토리얼 >세 개의 테이블(StudentSignUp, Incoming_Applications_Current 및 Halls)을 조인하는 SQL 보기를 만드는 방법은 무엇입니까?
데이터베이스 관리 분야에서는 여러 테이블의 데이터를 병합해야 하는 경우가 많습니다. 일반적인 시나리오에는 포괄적인 통찰력을 얻기 위해 3개 이상의 테이블을 조인하는 것이 포함됩니다. 이 예의 목표는 StudentSignUp, Incoming_Applications_Current 및 Halls라는 세 테이블의 정보를 원활하게 결합하는 뷰를 만드는 것입니다.
제공된 초기 쿼리는 StudentSignUp 및 Incoming_Applications_Current 테이블 조인에 중점을 두고 기숙사 기본 설정과 함께 학생 정보를 성공적으로 검색합니다. 그러나 기숙사 선호 사항은 해당 이름이 아닌 ID 번호로 표시됩니다. 뷰를 완성하려면 세 번째 테이블인 Halls를 병합해야 합니다.
수정된 쿼리를 사용하여 원하는 결과를 얻을 수 있습니다.
<code class="language-sql">SELECT s.StudentID, s.FName, s.LName, s.Gender, s.BirthDate, s.Email, r.HallPref1, h1.HallName AS HallPref1Name, r.HallPref2, h2.HallName AS HallPref2Name, r.HallPref3, h3.HallName AS HallPref3Name FROM dbo.StudentSignUp AS s INNER JOIN RoomSignUp.dbo.Incoming_Applications_Current AS r ON s.StudentID = r.StudentID INNER JOIN HallData.dbo.Halls AS h1 ON r.HallPref1 = h1.HallID INNER JOIN HallData.dbo.Halls AS h2 ON r.HallPref2 = h2.HallID INNER JOIN HallData.dbo.Halls AS h3 ON r.HallPref3 = h3.HallID;</code>
이 수정된 쿼리는 Incoming_Applications_Current 테이블과 Halls 테이블 사이에 3개의 추가 JOIN을 도입합니다. 각 JOIN은 HallPref ID를 일치 조건으로 사용하여 실행됩니다. 따라서 쿼리는 기숙사 ID뿐만 아니라 학생의 기숙사 이름 선호도를 포함하여 세 개의 테이블에서 필요한 모든 정보를 검색합니다.
이 포괄적인 쿼리를 구현하면 사람이 읽을 수 있는 이름으로 표시되는 기숙사 선호 사항을 포함하여 학생 정보에 대한 완전한 그림을 제공하는 뷰를 효과적으로 만들 수 있습니다.
위 내용은 세 개의 테이블(StudentSignUp, Incoming_Applications_Current 및 Halls)을 조인하는 SQL 보기를 만드는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!