sql- sum if() 用法举例

题目:

    从订单明细表(order_detail)中查询出所有购买过商品1和商品2,但是没有购买过商品3的用户

订单表 order_info

        

order_id (订单id)user_id (用户id)create_date (下单日期)total_amount (订单金额)
11012021-09-3029000.00
101032020-10-0228000.00

订单明细表 order_detail

       

order_detail_id(订单明细id)order_id(订单id)sku_id(商品id)create_date(下单日期)price(商品单价)sku_num(商品件数)
1112021-09-302000.002
2132021-09-305000.005
221042020-10-026000.001
231052020-10-02500.0024
241062020-10-022000.005

计算逻辑

1.使用差集

1. 将订单表与订单明细表进行join,获取所有用户,商品信息
     selectod.order_id,sku_id,user_idfrom  order_detail odjoin  order_info oi  on oi.order_id = od.order_id               t1

     

2.按照用户,商品,分组,统计用户购买单种商品的数量
    select user_id,sku_id,count(*) ctfrom t1group by user_id,sku_id                    t2
3.根据用户购买每种商品的数量,筛选购买1,2但是没有购买3的商品。
    selectuser_idfrom t2where sku_id in (1,2) and user_id not in (selectuser_idfrom t2where sku_id = 3)group by user_id
4.拼接最终SQL

    

with tmp1 as (selectsku_id,user_id,count(*) ctfrom (selectod.order_id,sku_id,user_idfrom order_detail odjoin order_info oion od.order_id = oi.order_id)t1group by sku_id,user_id
)selectuser_id
from tmp1
where sku_id in (1,2)
and user_id not in
(selectuser_id
from tmp1
where sku_id = 3)
group by user_id

2.使用sum if

  1. 将订单表与订单明细表进行join,获取所有用户,商品信息

      

order_detail odjoin order_info oi on od.order_id = oi.order_id
  2.按照用户,商品,分组,统计用户-商品的信息

     

    SELECToi.user_id,od.sku_idfrom t1group byoi.user_id,od.sku_id
  3.根据用户分组,使用sum..if.. 统计购买1,2但是没有购买3的用户。

    不难看出,使用sum if 可以统计购买1,2的用户。若不符合过滤条件,将不会展示用户信息

    同时,having后面直接添加聚合函数进行聚合,简化了在select语句写聚合函数的过程。

SELECTuser_id
from t3
group byuser_id
havingsum(if (sku_id = 3, -3, if (sku_id in (1, 2), 1, 0))) = 2
  4.最终SQL
SELECTuser_id
from(SELECToi.user_id,od.sku_idfromorder_detail odjoin order_info oi on od.order_id = oi.order_idgroup byoi.user_id,od.sku_id) t
group byuser_id
havingsum(if (sku_id = 3, -3, if (sku_id in (1, 2), 1, 0))) = 2

------ 第二种是某位大佬写的,更推荐第二种写法,不禁肃然起敬。

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

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

相关文章

全罐喂养一个月多少钱?适合全罐喂养的猫罐头推荐

不少铲屎官一直没有办法get到猫罐头对猫咪的好处,或者get到了又觉得给猫咪买猫罐头好贵,看到其他铲屎官都开始全罐喂养了,但是自己却迟迟下不了手,犹犹豫豫的不知道全罐喂养一个月多少钱? 今天,铲龄15年的…

FreeBSD安装postgresql

安装postgresql15 $ sudo pkg install postgresql15-server postgresql15-client # 安装完之后会自动注册到服务列表 rootfreebsd14-11-199:~ # service -l|grep post postgresql # 将postgresl添加到开机自启动 rootfreebsd14-11-199:~ # service -e|grep post rootfreebsd1…

Python实现Excel切片删除功能(附源码)

使用Python实现Excel中的“切片删除”功能(附源码) 先上效果图!!! 如下是需要处理的Excel文件,可以看到在27行和117行处的E列存在数据不一致情况,需进行“切片删除” 运行结果图如下&#xff…

【MySQL】union (all) 后 order by 子查询排序不生效问题解决方案

力扣题 1、题目地址 2308. 按性别排列表格 2、模拟表 表:Genders Column NameTypeuser_idintgendervarchar user_id 是该表的主键(具有唯一值的列)。gender 的值是 ‘female’,‘male’,‘other’ 之一。该表中的每一行都包含用户的 ID…

查看服务器资源使用情况

查看服务器资源使用情况 一、top命令二、理解IOPS三、腾讯云机器cvm四、iotop五、atop六、查看内存使用情况一、top命令 "top"命令是一个Linux系统的实用工具,用于动态监视系统的运行状态。它会实时显示系统中正在运行的进程列表,并按照CPU使用率、内存使用率等指…

【前端架构】前端通用架构

一个强大的前端通用架构应该具备多种能力,以支持现代化的应用程序开发和提高开发效率。以下是一些前端通用架构应该具备的关键能力: 模块化和组件化:支持模块化开发和组件化架构,能够将应用拆分为独立的模块和组件,以便…

leetcode 2418. 按身高排序

题目 给你一个字符串数组 names ,和一个由 互不相同 的正整数组成的数组 heights 。两个数组的长度均为 n 。 对于每个下标 i,names[i] 和 heights[i] 表示第 i 个人的名字和身高。 请按身高 降序 顺序返回对应的名字数组 names 。 解题方法&#xff…

Go新项目-为何选Gin框架?(0)

先说结论:我们选型Gin框架 早在大概在2019年下旬,由于内部一个多线程上传的需求,考虑到Go协程的优势; 内部采用Gin框架编写了内部的数据上传平台BAP,采用GinVue开发,但前期没考虑到工程化思维,导…

开源世界许可证Copyleft GPL LGPL MIT BSD Apache

Copyleft Copyleft利用版权法来提供分发作品的副本和修改版本的权利,并要求在作品的修改版本中保留同样的权利。换句话说,copyleft是让创造性的作品可以自由修改,并要求作品的所有修改和扩展版本也是自由的一般方法。 GPL是首个通用的copyleft许可证。 GNU通用公共许可证(…

VUE的插槽介绍

什么是插槽 插槽(Slot)是 vue 为组件的封装者提供的功能,允许开发者在封装组件时,把不确定的、希望由用户指定的部分定义为插槽。 可以把插槽认为是组件封装期间,为用户预留的内容的占位符,在组件的使用者…

Vue3入门

文章目录 一、Vue3介绍二、Vue3项目创建1)使用vue-cli创建vue3项目2)使用vite创建vue3项目 三、Setup函数vue2的创建vue实例和vue3创建vue实例的区别 四、ref和reactive1)ref函数2)reactive函数3)reactive对比ref4&…

苹果最新系统iOS 17的调试和适配方法 - Xcode 14.3.1 真机调试指南

最近苹果发布了iOS 17作为其最新操作系统版本,作为开发者,你可能需要了解如何在Xcode 14.3.1中进行真机调试和适配。本文将为你详细介绍步骤和注意事项。 I. 检查Xcode版本 在开始之前,确保你已经安装了Xcode 14.3.1或更高版本。你可以在Xco…

利用先进的条形码识别和 OCR 技术改善机场行李处理

机场每年处理数百万件行李,主要航空公司每家运输超过 1 亿件行李。每年有 2500 万件行李被错误处理,正确处理至关重要。使用最好的技术是关键,首先是从机场到飞机的正确转乘。 行李分拣 Dynamsoft 的客户是一家机场行李分拣解决方案提供商。…

排序算法-快速排序(含C语言代码示例)

一、算法介绍 快速排序(QuickSort)是一种常用的高效排序算法,由Tony Hoare在1960年提出。它采用分治法(Divide and Conquer)策略,通过将原始数组分成较小的子数组来解决排序问题。下面是对快速排序的详细介…

c语言将csv文件中的XY轴数据转换为html波形图

目标: c语言实现一个最简化的csv转html波形图显示方案。 csv文件格式: 共两行数据,第一行是x轴数据,第二行是y轴数据。 csv文件名分为3段: 波形图名称,x轴名称,y轴名称。 c代码: int csv2html…

网络命令ping和telnet

1. 请解释ping和telnet的工作原理。 ping和telnet是两种常用的网络工具,其工作原理分别如下: ping: 目的:ping主要用于检查网络是否通畅以及测量网络连接速度。工作原理:ping是基于ICMP(Internet Control …

HTML5:dialog

JavaScript 练手小技巧&#xff1a;HTML5 的 dialog 标签制作对话框_dialog html-CSDN博客 <dialog id"dialog"> <h2 align"center">修改</h2> <input type"text" id"title1" placeholder"标题" value…

智能小程序小部件(Widget)导航、地图、画布等组件,以及开放能力、原生组件说明

智能小程序小部件(Widget)导航、地图、画布等组件&#xff0c;以及开放能力、原生组件说明。 导航组件 navigator 页面链接&#xff0c;控制小程序的跳转。navigator 子节点的背景色应为透明色。 属性说明 属性名类型默认值必填说明urlstring是跳转地址deltanumber1否当 …

海思SD3403,SS928/926,hi3519dv500,hi3516dv500移植yolov7,yolov8(9)

上一节yolov8的训练已经完成了,现在要开始做模型的转换了,这里和yolov7方式相似,但是有一些差异,尤其是yolov7的不带NMS部分的输出顺序和yolov8的输出顺序与格式是有差异的。 首先还是要自己手动加入rpn_op,这里包含了filter,sort,nms部分。 我们一个一个看,首先filter.py…

IDEA 2022.3.3 安装教程

1.下载2022.3.3版本IDEA 链接&#xff1a;https://pan.baidu.com/s/1z-Yfl7fWHgqz8SQLn2-u0g?pwd949u 提取码&#xff1a;949u 2.安装 下载完成后&#xff0c;双击exe安装包&#xff0c; 点击next 3.选择方式3 4.将下面文件复制到任意位置&#xff08;不要有中文路径&…