我有2个表,“T_COMMON_COUNTRY”和“T_HEI_STUDENTDATA”。使用左联接我加入了这些表
这是我的查询
SELECT
[T_COMMON_COUNTRY].[COUNTRY_ID],
[T_COMMON_COUNTRY].[COUNTRY],
[T_HEI_STUDENTDATA].[STUDENT_ID]
FROM ([T_COMMON_COUNTRY]
LEFT JOIN [T_HEI_STUDENTDATA]
ON [T_COMMON_COUNTRY].[COUNTRY] = [T_HEI_STUDENTDATA].[STDCOUNTRY])
现在我得到这样的 View
| Country ID | County | Student ID |
| 1 | USA | 12 |
| 1 | USA | 5 |
| 2 | UK | 11 |
| 2 | UK | 2 |
我想计算与一个国家/地区相关的学生人数(Student_IDs),
我想得到一个完全像下面的 View
| Country ID | County | Students |
| 1 | USA | 2 |
| 2 | UK | 2 |
最佳答案
使用COUNT
函数生成按国家划分的学生人数
试试这个:
SELECT C.[COUNTRY_ID], C.[COUNTRY], COUNT(S.[STUDENT_ID]) AS StudentCount
FROM [T_COMMON_COUNTRY] C
LEFT JOIN [T_HEI_STUDENTDATA] S ON C.[COUNTRY] = S.[STDCOUNTRY]
GROUP BY C.[COUNTRY_ID], C.[COUNTRY];
关于sql - 连接2个表并计算SQL中特定于出现次数的字段,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/27242708/