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‘,其中至少有一名教练工作。
CAn有人帮我吗?
发布于 2012-12-11 10:16:02
在Gym
和Works
表之间执行一个简单的INNER JOIN
就可以了:
SELECT DISTINCT g.*
FROM
Gym g
JOIN Works w
ON g.eid = w.eid
WHERE
g.district = 'Casanova'
如果该健身房中至少没有一名教练在工作,则此查询将不会返回任何内容。
发布于 2012-12-11 10:14:24
作为参考,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表中获取列,我几乎感觉不到它“更简单”。你来当法官吧。
https://stackoverflow.com/questions/13812548
复制相似问题