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
相关推荐
Lx3522 小时前
排序缓冲区调优:sort_buffer_size的合理配置
sql·mysql·性能优化
feifeigo1239 天前
Java 正则表达式高级用法
java·mysql·正则表达式
敏叔V5879 天前
大模型Text2SQL之在CentOS上使用yum安装与使用MySQL
linux·mysql·centos
程序猿小D9 天前
[附源码+数据库+毕业论文]基于Spring+MyBatis+MySQL+Maven+Vue实现的校园二手交易平台管理系统,推荐!
java·数据库·mysql·spring·vue·毕业设计·校园二手交易平台
张太行_9 天前
MySQL与Excel比较
数据库·mysql·excel
斯普信专业组9 天前
MySQL 8.x配置MGR高可用+ProxySQL读写分离(二):ProxySQL配置MySQL代理及读写分离
数据库·mysql
中国lanwp9 天前
InnoDB Cluster 与 NDB Cluster 对比及部署指南
mysql
亲爱的非洲野猪9 天前
MySQL 事务实现机制详解
数据库·mysql
程序员岳焱9 天前
Java 与 MySQL 性能优化:MySQL性能指标解读与监控方法
后端·mysql·性能优化
i小溪9 天前
着重介绍一下sql语句中的JSON_UNQUOTE、JSON_EXTRACT
数据库·mysql