• 数据库case,when学习


    前几天工作中遇到了一个数据库统计相关的东西,主要使用case,when实现。如今说说基本情况:
    有两个表school,studens,当中
    school表结构例如以下:
    school表结构
    students表结构例如以下:
    studens表结构
    当中sex=1代表男,sex=2代表女
    现要求出现例如以下的结果集:
    学校id,学校名,学校总人数。男生总人数。女生总人数
    方案:
    1。将school表和students表分别查询统计出学校总人数,男生总人数,女生总人数,然后将结果集拼起来即可了。此方法比較传统,想法简单,可是sql过长。


    2.採用case,when语句,在count聚合函数使用,详细代码例如以下:

    SELECT  c.id ,
            c.NAME ,
            ( c.boyCount + c.girlCount ) AS TotalCount ,
            c.boyCount ,
            c.girlCount
    FROM    ( SELECT    b.id ,
                        b.name ,
                        COUNT(CASE WHEN a.sex = 1 THEN 1
                                   ELSE NULL
                              END) AS boyCount ,
                        COUNT(CASE WHEN a.sex = 2 THEN 1
                                   ELSE NULL
                              END) AS girlCount
              FROM      [guagua_new_event_system_test].[dbo].[students] a ,
                        [guagua_new_event_system_test].[dbo].[school] b
              WHERE     a.school_id = b.id
              GROUP BY  b.id ,
                        b.name
            ) AS c

    算是数据库的一种学习吧!


    路漫漫其修远兮。吾将上下而求索!

  • 相关阅读:
    云服务器配置
    linux云服务器的配置
    Python进阶练习与爬取豆瓣T250的影片相关信息
    实时爬取疫情动态变化并进行可视化展示
    python基础学习
    异步实现用户名的校验
    人月神话读书笔记(一)
    第三周学习进度博客
    CentOS7.4下编译Hadoop-2.7.6
    Linux 内存使用率
  • 原文地址:https://www.cnblogs.com/yfceshi/p/7304940.html
Copyright © 2020-2023  润新知