1. ホーム
  2. sql

[解決済み] 3つのテーブルを持つSQL Inner-join?

2022-03-14 06:12:13

質問

ビューで3つのテーブルを結合しようとしていますが、以下のような状況です。

この大学のキャンパスに住むことを志願している学生の情報を含むテーブルがあります。私は、各学生のホール希望 (3つ) をリストアップする別のテーブルを持っています。しかし、これらの各希望は単にID番号であり、ID番号は3番目のテーブル(このデータベースを設計していない...)で対応するホール名を持っています。

かなり、私は INNER JOIN を、それぞれの好みと情報とともにテーブルに並べると、次のような結果になります。

 John Doe | 923423 | Incoming Student | 005

ここで 005 は、その HallID . そこで、今度はその HallID を3つ目のテーブルに追加し、このテーブルには HallIDHallName .

ということで、大体、こんな感じにしたいんですが...。

 John Doe | 923423 | Incoming Student | Foley Hall <---(INSTEAD OF 005)

現在、私が持っているものは以下の通りです。

SELECT
  s.StudentID, s.FName, 
  s.LName, s.Gender, s.BirthDate, s.Email, 
  r.HallPref1, r.HallPref2, r.HallPref3
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 h 
    ON r.HallPref1 = h.HallID

解決方法は?

以下のようにすることができます(テーブルのフィールドなどを推測しています)。

SELECT s.studentname
    , s.studentid
    , s.studentdesc
    , h.hallname
FROM students s
INNER JOIN hallprefs hp
    on s.studentid = hp.studentid
INNER JOIN halls h
    on hp.hallid = h.hallid

複数のホールを利用したいというご要望に基づき、このような方法をとることができます。各部屋のプレフィックス ID に対して、Hall テーブルに複数回ジョインするだけです。

SELECT     s.StudentID
    , s.FName
    , s.LName
    , s.Gender
    , s.BirthDate
    , s.Email
    , r.HallPref1
    , h1.hallName as Pref1HallName
    , r.HallPref2 
    , h2.hallName as Pref2HallName
    , r.HallPref3
    , h3.hallName as Pref3HallName
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