>데이터 베이스 >MySQL 튜토리얼 >세 개의 테이블(StudentSignUp, Incoming_Applications_Current 및 Halls)을 조인하는 SQL 보기를 만드는 방법은 무엇입니까?

세 개의 테이블(StudentSignUp, Incoming_Applications_Current 및 Halls)을 조인하는 SQL 보기를 만드는 방법은 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2025-01-15 22:32:44432검색

How to Create an SQL View Joining Three Tables (StudentSignUp, Incoming_Applications_Current, and Halls)?

SQL 보기에서 3개의 테이블 조인

데이터베이스 관리 분야에서는 여러 테이블의 데이터를 병합해야 하는 경우가 많습니다. 일반적인 시나리오에는 포괄적인 통찰력을 얻기 위해 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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