--第一次想到的答案,突然发现少了一个来自Madrid的FISSA订单,FISSA订单数量为0,所以在Orders表中没有出现,所以上面的写法会少一个.
--推翻了上面的答案,又想到了用表的连接,而用内连接出现的情况会和上面的一样,所以我选择了左连接,如下:
代码如下:
select C.customerid as 消费者,count(O.customerid) as 订单数
from dbo.Customers as C left join dbo.Orders as O on C.customerid = O.customerid
where C.city= 'Madrid'
group by C.customerid
having count(C.customerid) < 3
结果如图所示:
select C.customerid as 消费者,count(O.customerid) as 订单数
from dbo.Customers as C left join dbo.Orders as O on C.customerid = O.customerid
where C.city= 'Madrid'
group by C.customerid
having count(C.customerid) < 3
结果如图所示:
--查询发现是正确的。
--分析查看不带条件的左连接
代码如下:
select * from dbo.Customers as C left join dbo.Orders as O on C.customerid = O.customerid
select * from dbo.Customers as C left join dbo.Orders as O on C.customerid = O.customerid
代码如下:
select * from dbo.Customers as C left join dbo.Orders as O on C.customerid = O.customerid
结果如图所示:
select * from dbo.Customers as C left join dbo.Orders as O on C.customerid = O.customerid
结果如图所示:
--书中给的标准答案是:
代码如下:
select C.customerid , count(O.orderid) as numorders
from dbo.Customers as C left join dbo.Orders as O on C.customerid = O.customerid
where C.city= 'Madrid'
group by C.customerid
having count(O.orderid) < 3
order by numorders
结果如图所示:
select C.customerid , count(O.orderid) as numorders
from dbo.Customers as C left join dbo.Orders as O on C.customerid = O.customerid
where C.city= 'Madrid'
group by C.customerid
having count(O.orderid) < 3
order by numorders
结果如图所示:
--书中给的只是多了一个order by 进行定义了排序方式(以numorders这一列的升序进行排序)
- 欢迎访问木庄网络博客
- 可复制:代码框内的文字。
- 方法:Ctrl+C。