我有三张表:
Carrier(CarrierID(PK), FirstName, LastName)
Customer(CustomerID(PK), FirstName, LastName, RouteID(FK))
Route(RouteID(PK), CarrierID(FK), RouteName)每条路由只有一个运营商。
我需要显示每个运营商负责的客户数量。
我知道我需要使用CarrierID来获取RouteID,然后使用RouteID来计算具有该RouteID的客户的行数。
有人能给我解释一下SELECT语句是什么样子的吗?
发布于 2017-03-14 04:00:05
如果需要不同数量的客户,可以使用count(distinct ..)group by和join
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.Lastnamehttps://stackoverflow.com/questions/42772279
复制相似问题