SQL使用列值从另一个表中获取列值,然后使用THAT值从第三个表中获取具有该值的列数?

时间:2017-03-13 19:53:38

标签: sql select

我有三张桌子:

Carrier(CarrierID(PK), FirstName, LastName)
Customer(CustomerID(PK), FirstName, LastName, RouteID(FK))
Route(RouteID(PK), CarrierID(FK), RouteName)

每条路线只有一个承运人。

我需要显示每个运营商负责的客户数量。

我知道我需要使用CarrierID来获取RouteID,然后使用RouteID来计算具有该RouteID的Customers行。

有人可以向我解释一下SELECT语句的外观吗?

1 个答案:

答案 0 :(得分:0)

如果您需要不同数量的客户,您可以使用count(distinct ..)group by并加入

select r.CarrierID, count(distinct CustomerID )
from Route r
inner join Customer c on c.RouteID = r.RouteID
group by r.CarrierID


select r.CarrierID, c2.Firstname, c2.Lastname, count(distinct CustomerID )
from Route r
inner join Customer c on c.RouteID = r.RouteID
inner join Carrier c2 on c2.CarrierID = r.CarrierID
group by r.CarrierID, c2.Firstname, c2.Lastname