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

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

先看一下效果:

话不多说,直接上SQL

SELECTdate_range.date AS 日期,COUNT( oco.id ) AS 总订单,COUNT( oco.pay_price ) AS 成功订单,IFNULL( sum( oco.pay_price ), 0 ) AS 客户付款金额 
FROM(
SELECTDATE( '2023-11-01' ) + INTERVAL t0.num DAY AS date 
FROM(
SELECT( a.num + b.num + c.num + d.num + e.num ) num 
FROM(
SELECT0 num UNION ALL
SELECT1 num UNION ALL
SELECT2 num UNION ALL
SELECT3 num UNION ALL
SELECT4 num UNION ALL
SELECT5 num UNION ALL
SELECT6 num UNION ALL
SELECT7 num UNION ALL
SELECT8 num UNION ALL
SELECT9 num ) a,(
SELECT0 num UNION ALL
SELECT10 num UNION ALL
SELECT20 num UNION ALL
SELECT30 num UNION ALL
SELECT40 num UNION ALL
SELECT50 num UNION ALL
SELECT60 num UNION ALL
SELECT70 num UNION ALL
SELECT80 num UNION ALL
SELECT90 num ) b,(
SELECT0 num UNION ALL
SELECT100 num UNION ALL
SELECT200 num UNION ALL
SELECT300 num UNION ALL
SELECT400 num UNION ALL
SELECT500 num UNION ALL
SELECT600 num UNION ALL
SELECT700 num UNION ALL
SELECT800 num UNION ALL
SELECT900 num ) c,(
SELECT0 num UNION ALL
SELECT1000 num UNION ALL
SELECT2000 num UNION ALL
SELECT3000 num UNION ALL
SELECT4000 num UNION ALL
SELECT5000 num UNION ALL
SELECT6000 num UNION ALL
SELECT7000 num UNION ALL
SELECT8000 num UNION ALL
SELECT9000 num ) d,(
SELECT0 num UNION ALL
SELECT10000 num UNION ALL
SELECT20000 num UNION ALL
SELECT30000 num UNION ALL
SELECT40000 num UNION ALL
SELECT50000 num UNION ALL
SELECT60000 num UNION ALL
SELECT70000 num UNION ALL
SELECT80000 num UNION ALL
SELECT90000 num ) e ) t0 
WHEREDATE( '2023-11-01' ) + INTERVAL t0.num DAY <= '2023-11-31' ) date_rangeLEFT JOIN user_order oco ON date_range.date = DATE( oco.create_time ) AND oco.company_id = 15 
GROUP BYdate_range.date 
ORDER BYdate_range.date ASC;

讲解一下难点:

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

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

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

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/238101.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

二分类问题中评估模型的示例及释义:召准率、召回率等

1、评估参数定义 1.1、召准率&#xff08;Precision&#xff09; 召准率是衡量模型预测正类标签时的准确度的指标。它计算的是模型预测的正类中真正为正类的比例。换句话说&#xff0c;召准率表示在所有预测为正类的实例中&#xff0c;正确识别为正类的实例所占的比例。 其中…

H5 Canvas 打飞机青春版

没事儿写写练习一下&#xff0c;说不准哪天就用到今天所用到的知识点了呢。 在线链接 https://linyisonger.github.io/H5.Examples/?name./053.%E9%A3%9E%E6%9C%BA%E5%A4%A7%E6%88%98.html 功能清单 循环滚动背景 矩形碰撞 随机生成敌人 飞机左右移动 苹果屏蔽长按 移动端屏…

在CentOS系统下的Tomcat8.5或9安装SSL证书

您可以在CentOS系统下的Tomcat服务器安装SSL证书&#xff0c;实现通过HTTPS安全访问Web服务。本文介绍如何CentOS系统下Tomcat 8.5或9安装SSL证书。 环境准备 操作系统&#xff1a;CentOS 7.6 64位 Web服务器&#xff1a;Tomcat 8.5或9 说明 Tomcat服务器需要提前安装JDK环…

SpringSecurity 用户帐号已被锁定

SpringSecurity 用户帐号已被锁定 01 异常发生场景 当我自定义登录接口时以下是我的UserDetailsService和UserDetails接口的实现类 Service public class UserDetailsServiceImpl implements UserDetailsService {Autowiredprivate MsUserServiceImp msUserServiceImp;Overr…

SeaTunnel扩展Source插件,自定义connector-webservice

代码结构 在seatunnel-connectors-v2中新建connector-webservice模块&#xff0c;可以直接赋值connector-http-base模块&#xff0c;webservice和http的方式比较类似&#xff0c;有些类直接复制了http中的代码。 核心类有WebserviceConfig&#xff0c;WebserviceParameter&am…

WPF Mvvm模式下面如何将事件映射到ViewModel层

前言 平常用惯了Command绑定,都快忘记传统的基于事件编程模式了,但是Commond模式里面有个明显的问题,就是你无法获取到事件源的参数。很多大聪明肯定会说,这还不简单,通过自己写控件,给控件加个自定义属性不就行了,想要啥事件就写啥事件进去,完全自主可控。但是对于写…

列表插槽使用

{label: 是否展示,prop: isShow,solt: true, }<!--自定义列--><template slot-scope"scope" slot"isShow"><div style"color: red;cursor: pointer" focus"getIsShow(scope.row)" ><el-switch v-model"sco…

良品铺子“降价不降质”:利他主义,零食新成长逻辑

最近&#xff0c;男大学生组团穿军大衣&#xff0c;女大学生集体穿花棉袄&#xff0c;火遍全网。 相当一批大学生发现&#xff0c;军大衣、花棉袄在保暖上不输羽绒服&#xff0c;而且价格还便宜。这股风潮背后&#xff0c;其实映射出当下年轻人在消费上变得愈发&#xff1a; …

C# 动态编译代码并执行

写在前面 本文采用动态编译的方式&#xff0c;对目标文件code.txt中的C#代码进行实时编译并调用&#xff1b;当然也可以直接在代码中直接装配或读取已有的代码文本&#xff0c;动态编译可以用于很多需要热更新的场景&#xff0c;实现无需重启程序也能达到更新代码的需求。 代…

算法题--排椅子(贪心)

题目链接 code #include<bits/stdc.h> using namespace std;struct node{int indx;//用来存储数组下标int cnt;//用来计数 };bool cmp(node a,node b){ //判断是否是数字最大的一个就是经过最多谈话人的道return a.cnt>b.cnt; } node row[2010],cow[2010];bool cmp…

MatrixOne Meetup回顾 | 深圳站

11月11日&#xff0c;MatrixOne 社区在深圳成功举办了第二次 MatrixOne Meetup。活动当天&#xff0c;数十位外部小伙伴到场参与&#xff0c;一同分享云原生数据库相关知识内容。此次活动&#xff0c;我们也邀请了来自深圳素问智能的外部讲师&#xff0c;分享了目前火爆的大模型…

什么是死锁?如何产生死锁?死锁的必要条件?怎么解决死锁?

🔒1、什么是死锁 死锁是一个非常让程序猿烦恼的问题,一旦所写的程序有了死锁,那么程序就无法执行下去,会出现严重的 bug,并且死锁非常隐蔽,我们不会轻易发现它,在开发阶段,不经意期间我们就会写出死锁,很难检测出来。 那么什么是死锁呢?竟然让我们如此烦恼。 “死…