3つのテーブルがあります。
場所
ID | NAME | TYPE |
1 | add1 | stat |
2 | add2 | coun |
3 | add3 | coun |
4 | add4 | coun |
5 | add5 | stat |
学校
ID | NAME
1 | sch1
2 | sch2
3 |sch3
学校の場所
ID |LOCATIONS_ID |SCHOOL_ID
1 | 1 |1
2 | 2 |2
3 | 3 |3
ここで、テーブルの場所にはアプリケーションのすべての場所が含まれています。学校の場所はIDによって呼び出されます。
クエリを使用するとき
select locations.name from locations where type="coun";
タイプが「coun」の名前が表示されます
しかし、school_locationsのみがtype = "coun"を持つlocations.nameを表示したい
私はクエリに従ってみましたが、どれも機能していないようです
select locations.name
from locations
where type="coun"
inner join school_locations
on locations.id=school_locations.location_id
inner join schools
on school_locations.school.id=schools.id;
そして
select locations.name
from locations
inner join school_locations
on locations.id=school_locations.location_id
inner join schools
on school_locations.school.id=schools.id where type="coun";
クエリで複数の内部結合を使用することは可能ですか、それとも別の方法がありますか?
SELECT `locations`.`name`
FROM `locations`
INNER JOIN `school_locations`
ON `locations`.`id` = `school_locations`.`location_id`
INNER JOIN `schools`
ON `school_locations`.`school_id` = `schools_id`
WHERE `type` = 'coun';
WHERE
句はステートメントの最後になければなりません
これを試して:
SELECT Locations.Name, Schools.Name
FROM Locations
INNER JOIN School_Locations ON School_Locations.Locations_Id = Locations.Id
INNER JOIN Schools ON School.Id = Schools_Locations.School_Id
WHERE Locations.Type = "coun"
LocationsをSchool_Locationsに参加させてから、School_LocationsをSchoolに参加させることができます。これにより、関連するすべてのロケーションと学校のセットが形成され、WHERE句を使用してロケーションが「coun」タイプのロケーションとスクールに調整できます。
これを試して :
SELECT
(
SELECT
`NAME`
FROM
locations
WHERE
ID = school_locations.LOCATION_ID
) as `NAME`
FROM
school_locations
WHERE
(
SELECT
`TYPE`
FROM
locations
WHERE
ID = school_locations.LOCATION_ID
) = 'coun';