我有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/

10-12 06:41