我正在研究SQL,我有这些表:
CREATE TABLE Gym (
eid INT PRIMARY KEY,
name VARCHAR(127) UNIQUE,
district VARCHAR(127),
area INT);
CREATE TABLE Trainer (
id INT PRIMARY KEY,
name VARCHAR(127),
birth_year INT,
year_credentials_expiry INT
);
CREATE TABLE Works (
eid INT,
id INT,
since INT,
FOREIGN KEY (eid) REFERENCES Gym (eid),
FOREIGN KEY (id) REFERENCES Trainer (id),
PRIMARY KEY (eid,id));
我想建立一个查询,可以告诉我“Casanova”区的健身房名称,至少有一名教练在工作。
我一直在考虑使用EXISTS运算符,但必须有一个更简单的方法。 有谁帮助我?
答案 0 :(得分:0)
供参考,EXISTS查询:
select *
from Gym g
where district = 'Casanova'
and exists (select *
from Works w
where w.eid = g.eid);
为什么你认为应该采用“更简单”的方法? 另一种方法是在三维连接中列出Gym表中的所有列,只有在有一个训练师加入时才会有效。
select distinct g.eid, g.name, g.district, g.area
from Gym g
join Works w on w.eid = g.eid
where g.district = 'Casanova';
但是鉴于你需要使用DISTINCT从Gym表中获取列,我几乎感觉不到它“更简单”。你是法官。
答案 1 :(得分:0)
INNER JOIN
和Gym
表之间的简单Works
即可:
SELECT DISTINCT g.*
FROM
Gym g
JOIN Works w
ON g.eid = w.eid
WHERE
g.district = 'Casanova'
如果在该健身房中没有至少一名教练工作,则此查询将不返回任何内容。