【问题标题】:Get some set of values in SQL Server在 SQL Server 中获取一组值
【发布时间】:2020-06-01 07:36:18
【问题描述】:

我有一个查询,在这个查询中我需要获取每个学区的多个班级(班级计数)。这里只有上课的人来。所以我需要证明该地区也没有课程。

我的District 表包含 25 个值。我的班级覆盖表有 3 个地区的 5 个值。我需要显示所有地区。

代码

SELECT 
    CC.DistrictId, D.DistrictName,
    COUNT(D.DistrictId) AS DistrictCount
FROM
    TBL_T_ClassCoverage CC
LEFT JOIN 
    [dbo].[TBL_M_District] D ON CC.DistrictId = D.DistrictId
WHERE 
    CC.IsActive = 1 
GROUP BY
    CC.DistrictId, D.DistrictName
ORDER BY
    DistrictId ASC

【问题讨论】:

    标签: c# sql sql-server asp.net-mvc


    【解决方案1】:

    您需要以其他方式连接您的表,从地区到班级,以确保所有地区值都在输出中:

      SELECT D.DistrictId, D.DistrictName, COUNT(CC.DistrictId) AS DistrictCount
      FROM [dbo].[TBL_M_District] D
      LEFT JOIN TBL_T_ClassCoverage CC
      ON CC.DistrictId = D.DistrictId AND CC.IsActive = 1 
      GROUP BY D.DistrictId, D.DistrictName
      ORDER BY D.DistrictId ASC
    

    【讨论】:

      【解决方案2】:

      基本上你需要right join而不是left join

      SELECT CC.DistrictId, D.DistrictName, Count(D.DistrictId) AS DistrictCount
      FROM TBL_T_ClassCoverage CC
      RIGHT JOIN [dbo].[TBL_M_District] D ON CC.DistrictId = D.DistrictId
      WHERE CC.IsActive = 1 
      GROUP BY CC.DistrictId, D.DistrictName
      ORDER BY DistrictId ASC
      

      【讨论】:

        猜你喜欢
        • 2014-05-15
        • 2018-11-08
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        相关资源
        最近更新 更多