1

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

4

2 回答 2

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 表中获取列,我几乎不觉得它“更简单”。你来做法官。

于 2012-12-11T02:14:24.457 回答
0

一个简单的INNER JOINbetween GymandWorks表就可以了:

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

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

于 2012-12-11T02:16:01.750 回答