gpt4 book ai didi

SQL : get one particular book owner

转载 作者:行者123 更新时间:2023-12-04 18:30:44 25 4
gpt4 key购买 nike

我有一个 Student 表,其中包含如下列:

| email (PK) | name |

我有一个书 table ,里面有这样的列:

| bookid(PK) | title |

我有一个复制表,上面有人们拥有的书籍的副本

| emailofOwner(FK to student.email) | bookid(FK to book.bookid) |

一个学生当然可以拥有多本书。我的目标是找到只拥有 1 本这样的书的学生的名字,除了 bookid = 3 之外别无其他;

我试图找到只拥有一本书的人。

select c.emailofOwner
from copy c
group by c.emailofOwner
having count(*) = 1 ;

最佳答案

SELECT t1.name
FROM student t1
INNER JOIN
(
SELECT emailofOwner
FROM copy
GROUP BY emailofOwner
HAVING COUNT(DISTINCT bookid) = 1 AND MAX(bookid) = 3
) t2
ON t1.email = t2.emailofOwner

上面的查询使用子查询来限制只有一本 ID 为 3 的学生。子查询与您的尝试相同,只是它添加了最大图书 ID 为 3 的限制。在这种情况下,由于每个保留组只有一本书,因此这只是检查图书 ID 的值。

关于SQL : get one particular book owner,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39313050/

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