gpt4 book ai didi

sql - 使用一个查询中的 id 值到另一表中具有相同 id 的对应列

转载 作者:行者123 更新时间:2023-11-29 11:59:49 24 4
gpt4 key购买 nike

这个问题有点含糊,我深表歉意,希望下面的例子能解决这个问题。这是一个相当基本的问题,我似乎无法以我非常有限的知识和 SQL 相关词汇找到正确的解决方案

有一 table 人,

create table People (
id integer,
name LongName,
primary key (id)
);

还有一个是引用人的 worker

create table Workers (
id integer references People(id),
worktype varchar(20),
primary key (id)
);

最后是 works_for 关系

create table Works_for (
worker integer references Workers(id),
employer integer references Job(id),
primary key (worker,job)
);

现在我想要做的是让所有从事至少 20 份工作的人,这样我就可以通过以下查询获得正确的 id 列表:

SELECT worker
FROM Works_for
GROUP BY worker
HAVING COUNT(worker) > 20;

但是我也想得到这些 worker 的名字。我该怎么做?我已经尝试了很多事情,但我一直遇到错误。任何帮助将不胜感激!

最佳答案

您可以像这样连接表格并选择两个字段:

SELECT p.name, p.id
FROM People p
JOIN Works_for wf ON (p.id = wf.worker)
GROUP BY id
HAVING COUNT(wf.worker) > 20;

sqlfiddle

关于sql - 使用一个查询中的 id 值到另一表中具有相同 id 的对应列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29712397/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com