SQL统计数据之总结

一、查询SQL

复制代码
SELECT
    t1.规则编号 AS 编码,
    t1.规则描述 AS 名称,
    SUM( CASE WHEN t3.DATA_SOURCES = '00' THEN 1 ELSE 0 END ) AS '类型01',
    SUM( CASE WHEN t3.DATA_SOURCES = '01' THEN 1 ELSE 0 END ) AS '类型02',
    SUM( CASE WHEN t3.DATA_SOURCES = '02' THEN 1 ELSE 0 END ) AS '类型03',
    SUM( CASE WHEN t3.DATA_SOURCES = '03' THEN 1 ELSE 0 END ) AS '类型04' 
FROM
    (
SELECT
    'A_M_0001' AS 规则编号,
    '规则01' AS 规则描述 UNION ALL
SELECT
    'A_M_0002' AS 规则编号,
    '规则02' AS 规则描述 UNION ALL
SELECT
    'A_M_0003' AS 规则编号,
    '规则03' AS 规则描述 UNION ALL
SELECT
    'A_M_0005' AS 规则编号,
    '规则04' AS 规则描述 UNION ALL
SELECT
    'A_M_0007' AS 规则编号,
    '规则05' AS 规则描述 UNION ALL
SELECT
    'A_M_0006' AS 规则编号,
    '规则06' AS 规则描述 UNION ALL
SELECT
    'A_M_0008' AS 规则编号,
    '规则07' AS 规则描述 UNION ALL
SELECT
    'A_J_0001_01' AS 规则编号,
    '规则08' AS 规则描述 UNION ALL
SELECT
    'A_J_0001_12' AS 规则编号,
    '规则09' AS 规则描述 UNION ALL
SELECT
    'A_J_0001_02' AS 规则编号,
    '规则10' AS 规则描述 UNION ALL
SELECT
    'A_J_0001_03' AS 规则编号,
    '规则11' AS 规则描述 UNION ALL
SELECT
    'A_J_0001_13' AS 规则编号,
    '规则12' AS 规则描述 UNION ALL
SELECT
    'A_J_0001_05' AS 规则编号,
    '规则13' AS 规则描述 UNION ALL
SELECT
    'A_J_0001_11' AS 规则编号,
    '规则14' AS 规则描述 UNION ALL
SELECT
    'A_J_0001_06' AS 规则编号,
    '规则15' AS 规则描述 UNION ALL
SELECT
    'A_J_0001_14' AS 规则编号,
    '规则16' AS 规则描述 UNION ALL
SELECT
    'A_J_0001_07' AS 规则编号,
    '规则17' AS 规则描述 UNION ALL
SELECT
    'A_J_0001_15' AS 规则编号,
    '规则18' AS 规则描述 UNION ALL
SELECT
    'A_J_0002_01' AS 规则编号,
    '规则19' AS 规则描述 UNION ALL
SELECT
    'A_J_0002_02' AS 规则编号,
    '规则20' AS 规则描述 UNION ALL
SELECT
    'A_J_0002_03' AS 规则编号,
    '规则21' AS 规则描述 UNION ALL
SELECT
    'A_J_0002_04' AS 规则编号,
    '规则22' AS 规则描述 UNION ALL
SELECT
    'A_J_0002_05' AS 规则编号,
    '规则23' AS 规则描述 UNION ALL
SELECT
    'A_J_0002_06' AS 规则编号,
    '规则24' AS 规则描述 UNION ALL
SELECT
    'A_J_0002_07' AS 规则编号,
    '规则25' AS 规则描述 UNION ALL
SELECT
    'A_J_0003_01' AS 规则编号,
    '规则26' AS 规则描述 UNION ALL
SELECT
    'A_J_0003_02' AS 规则编号,
    '规则27' AS 规则描述 UNION ALL
SELECT
    'A_J_0003_05' AS 规则编号,
    '规则28' AS 规则描述 
    ) t1
    LEFT JOIN RAMS_TRIAL_CHECKLIST t2 ON t2.RULE_CODE like concat('%',t1.规则编号,'%')
    LEFT JOIN RAMS_TRIAL_CHECKLIST_EXT t3 ON t2.CHECKLIST_ID = t3.CHECKLIST_ID 
WHERE
    DATE( t2.UPDATE_TIME ) = CURDATE( ) - INTERVAL 1 DAY 
GROUP BY t1.规则编号,t1.规则描述;

二、查询结果

三、总结

1.数据库表中不存在的字段,可以利用以下sql进行处理:
SELECT '60019311' AS code, '北京' AS name

union all

SELECT '60019312' AS code, '上海' AS name

union all

SELECT '60019313' AS code, '广州' AS name

union all

SELECT '60019314' AS code, '重庆' AS name

2.量表关联查询,利用【Like】进行条件关联:

复制代码
RAMS_TRIAL_CHECKLIST t2 ON t2.RULE_CODE like concat('%',t1.规则编号,'%')

3.case when sql语句:

复制代码
CASE WHEN t3.DATA_SOURCES = '00' THEN 1 ELSE 0 END

4.查询系统当前时间的前一天数据的数量:

复制代码
SELECT COUNT(ID) FROM DATA WHERE DATE( UPDATE_TIME ) = CURDATE( ) - INTERVAL 1 DAY
相关推荐
lhw---999920 分钟前
C语言基本概念————讨论sqrt()和pow()函数与整数的关系
c语言·数据库·mysql
185的阿平21 分钟前
MVCC面试怎么答
java·mysql
奔跑吧邓邓子34 分钟前
【Python深入浅出㉙】Python3邂逅MySQL:开启数据交互之旅
数据库·python·mysql·交互
文牧之2 小时前
MySQL的字符集(Character Set)和排序规则(Collation)
运维·数据库·mysql
m0_663234013 小时前
flask后端开发(8):Flask连接MySQL数据库+ORM增删改查
数据库·mysql·flask
WeiZhihuicsdn5 小时前
Linux源码包安装MySQL数据库
linux·数据库·mysql
嘻嘻哈哈176 小时前
docker搭建mysql
mysql·docker·容器
猿java7 小时前
如何解决 MySQL主从复制延时问题?
java·mysql·面试
一线大码14 小时前
MySQL 存储过程未执行的问题排查过程
后端·sql·mysql
B站计算机毕业设计超人14 小时前
计算机毕业设计制造业MES生产管理平台 MES 生产制造源码+文档+运行视频+讲解视频)
java·spring boot·mysql·eclipse·tomcat·maven·web