首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >我需要一些关于SQL的提示

我需要一些关于SQL的提示
EN

Stack Overflow用户
提问于 2012-12-11 10:10:36
回答 2查看 50关注 0票数 1
代码语言:javascript
运行
复制
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有人帮我吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2012-12-11 10:16:02

GymWorks表之间执行一个简单的INNER JOIN就可以了:

代码语言:javascript
运行
复制
SELECT DISTINCT g.* 
FROM 
    Gym g
    JOIN Works w
    ON g.eid = w.eid
WHERE
    g.district = 'Casanova'

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

票数 0
EN

Stack Overflow用户

发布于 2012-12-11 10:14:24

作为参考,EXISTS查询:

代码语言:javascript
运行
复制
select *
  from Gym g
 where district = 'Casanova'
   and exists (select *
                 from Works w
                where w.eid = g.eid);

为什么你认为应该有一个“更简单”的方法?

另一种方法是在一个三向联接中列出Gym表中的所有列,只有在有需要联接的教练员的情况下才有效。

代码语言:javascript
运行
复制
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表中获取列,我几乎感觉不到它“更简单”。你来当法官吧。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/13812548

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档