首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SQL使用列值从另一个表中获取列值,然后使用该值从第三个表中获取具有该值的列的计数?

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

Stack Overflow用户
提问于 2017-03-14 03:53:38
回答 1查看 32关注 0票数 1

我有三张表:

代码语言:javascript
复制
Carrier(CarrierID(PK), FirstName, LastName)
Customer(CustomerID(PK), FirstName, LastName, RouteID(FK))
Route(RouteID(PK), CarrierID(FK), RouteName)

每条路由只有一个运营商。

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

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

有人能给我解释一下SELECT语句是什么样子的吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-03-14 04:00:05

如果需要不同数量的客户,可以使用count(distinct ..)group by和join

代码语言:javascript
复制
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
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/42772279

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档