这个sql有点东西,记录一下

我有一个需求:在订单表里面查询指定时间的订单数据,如果要是没有订单的话,需要展示当天日期和数据,数据为0

先看一下效果:

话不多说,直接上SQL

sql 复制代码
SELECT
	date_range.date AS 日期,
	COUNT( oco.id ) AS 总订单,
	COUNT( oco.pay_price ) AS 成功订单,
	IFNULL( sum( oco.pay_price ), 0 ) AS 客户付款金额 
FROM
	(
SELECT
	DATE( '2023-11-01' ) + INTERVAL t0.num DAY AS date 
FROM
	(
SELECT
	( a.num + b.num + c.num + d.num + e.num ) num 
FROM
	(
SELECT
	0 num UNION ALL
SELECT
	1 num UNION ALL
SELECT
	2 num UNION ALL
SELECT
	3 num UNION ALL
SELECT
	4 num UNION ALL
SELECT
	5 num UNION ALL
SELECT
	6 num UNION ALL
SELECT
	7 num UNION ALL
SELECT
	8 num UNION ALL
SELECT
	9 num 
	) a,
	(
SELECT
	0 num UNION ALL
SELECT
	10 num UNION ALL
SELECT
	20 num UNION ALL
SELECT
	30 num UNION ALL
SELECT
	40 num UNION ALL
SELECT
	50 num UNION ALL
SELECT
	60 num UNION ALL
SELECT
	70 num UNION ALL
SELECT
	80 num UNION ALL
SELECT
	90 num 
	) b,
	(
SELECT
	0 num UNION ALL
SELECT
	100 num UNION ALL
SELECT
	200 num UNION ALL
SELECT
	300 num UNION ALL
SELECT
	400 num UNION ALL
SELECT
	500 num UNION ALL
SELECT
	600 num UNION ALL
SELECT
	700 num UNION ALL
SELECT
	800 num UNION ALL
SELECT
	900 num 
	) c,
	(
SELECT
	0 num UNION ALL
SELECT
	1000 num UNION ALL
SELECT
	2000 num UNION ALL
SELECT
	3000 num UNION ALL
SELECT
	4000 num UNION ALL
SELECT
	5000 num UNION ALL
SELECT
	6000 num UNION ALL
SELECT
	7000 num UNION ALL
SELECT
	8000 num UNION ALL
SELECT
	9000 num 
	) d,
	(
SELECT
	0 num UNION ALL
SELECT
	10000 num UNION ALL
SELECT
	20000 num UNION ALL
SELECT
	30000 num UNION ALL
SELECT
	40000 num UNION ALL
SELECT
	50000 num UNION ALL
SELECT
	60000 num UNION ALL
SELECT
	70000 num UNION ALL
SELECT
	80000 num UNION ALL
SELECT
	90000 num 
	) e 
	) t0 
WHERE
	DATE( '2023-11-01' ) + INTERVAL t0.num DAY <= '2023-11-31' 
	) date_range
	LEFT JOIN user_order oco ON date_range.date = DATE( oco.create_time ) 
	AND oco.company_id = 15 
GROUP BY
	date_range.date 
ORDER BY
	date_range.date ASC;

讲解一下难点:

这条SQL语句的难点主要在于日期范围的生成和连接查询。首先,它使用了一个复杂的子查询来生成从指定日期开始的一个日期范围,这里使用了多个联结查询来生成连续的数字序列,然后通过日期相加得到连续的日期序列。这种技巧对于初学者来说可能比较难的

其次,它采用了左连接(LEFT JOIN)来连接日期范围表和订单表,并进行统计。左连接会返回左表中所有的行,即使右表中没有匹配的行。对于初学者来说,理解连接查询的逻辑和结果可能需要一些时间

最后,它使用了聚合函数COUNT和SUM来对订单数据进行统计,以及使用了IFNULL函数来处理空值。这些函数的使用对于初学者来说可能需要一些熟练度

因此,这条SQL语句的难点在于对日期范围的生成、连接查询和聚合函数的理解和熟练运用

相关推荐
运维行者_3 小时前
企业无线网络监控的挑战与智能化演进趋势
大数据·运维·服务器·网络·数据库
国强_dev4 小时前
技术探讨:使用 stunnel 加密转发数据库连接时,如何获取客户端真实 IP?
数据库·网络协议·tcp/ip
@insist1234 小时前
系统规划与管理师-信息系统规划核心工作要点解析
数据库·软考·系统规划与管理师·软件水平考试·系统规划与管理工程师
超级数据查看器4 小时前
超级数据查看器 v10.0 发布
java·大数据·数据库·sqlite·安卓
数安3000天4 小时前
增量数据如何自动分类分级,避免目录“过期“?
大数据·数据库
南墙上的石头5 小时前
麒麟 V10 重装人大金仓 V8R6 踩坑实录(含 MySQL 兼容模式)
数据库·mysql
画中有画6 小时前
论向量数据库在项目中的应用
数据库
spider_xcxc6 小时前
Redis 数据库高质量实践指南(一)
运维·数据库·redis·oracle·云计算
l1t7 小时前
在linux和windows中解决duckdb 1.6dev版本输出执行计划报错问题
linux·运维·数据库·windows·duckdb
执子手 吹散苍茫茫烟波7 小时前
RC 隔离级别下 MySQL InnoDB 死锁典型案例
数据库·mysql