作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
customers:
+-----------+-----------+
| cid | name |
+-----------+-----------+
| 1 | a |
| 2 | b |
| 3 | c |
+-----------+-----------+
pizza:
+-----------+-----------+
| pid | type |
+-----------+-----------+
| 1 | sausage |
| 2 | cheese |
| 3 | veggies |
| 4 | sausage |
| 5 | veggies |
| 6 | sausage |
| 7 | sausage |
+-----------+-----------+
orders:
+-----------+-----------+-----------+
| oid | cid | pid |
+-----------+-----------+-----------+
| 1 | 1 | 1 |
| 2 | 1 | 2 |
| 3 | 2 | 3 |
| 4 | 3 | 4 |
| 5 | 1 | 5 |
| 6 | 3 | 6 |
| 7 | 3 | 7 |
+-----------+-----------+-----------+
我在理解 sql 逻辑时遇到了一些麻烦。我如何找到没有订购所有 3 种披萨的顾客?这三种类型是香肠、奶酪和蔬菜。我需要使用 NOT EXIST
吗?
最佳答案
您可以使用 having
子句来查找订购少于 3 种披萨的客户:
select c.name
from customers c
join orders c
on c.cid = c.id
join pizza p
on p.id = c.pid
group by
c.name
having
count(distinct p.type) < 3
关于sql - 查找未订购所有 3 种比萨饼的顾客,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13459017/
我是一名优秀的程序员,十分优秀!