需要一些关于SQL的提示

时间:2012-12-11 02:10:36

标签: sql select exists

我正在研究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运算符,但必须有一个更简单的方法。 有谁帮助我?

2 个答案:

答案 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 JOINGym表之间的简单Works即可:

SELECT DISTINCT g.* 
FROM 
    Gym g
    JOIN Works w
    ON g.eid = w.eid
WHERE
    g.district = 'Casanova'

如果在该健身房中没有至少一名教练工作,则此查询将不返回任何内容。