SQL写法--行行比较

作者:青石路 时间:2024-01-12 18:53:34 

环境准备

数据库版本:MySQL 5.7.20-log

SQL写法--行行比较

建表 SQL


DROP TABLE IF EXISTS `t_ware_sale_statistics`;
CREATE TABLE `t_ware_sale_statistics` (
 `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键id',
 `business_id` bigint(20) NOT NULL COMMENT '业务机构编码',
 `ware_inside_code` bigint(20) NOT NULL COMMENT '商品自编码',
 `weight_sale_cnt_day` double(16,4) DEFAULT NULL COMMENT '平均日销量',
 `last_thirty_days_sales` double(16,4) DEFAULT NULL COMMENT '最近30天销量',
 `last_sixty_days_sales` double(16,4) DEFAULT NULL COMMENT '最近60天销量',
 `last_ninety_days_sales` double(16,4) DEFAULT NULL COMMENT '最近90天销量',
 `same_period_sale_qty_thirty` double(16,4) DEFAULT NULL COMMENT '去年同期30天销量',
 `same_period_sale_qty_sixty` double(16,4) DEFAULT NULL COMMENT '去年同期60天销量',
 `same_period_sale_qty_ninety` double(16,4) DEFAULT NULL COMMENT '去年同期90天销量',
 `create_user` bigint(20) DEFAULT NULL COMMENT '创建人',
 `create_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
 `modify_user` bigint(20) DEFAULT NULL COMMENT '最终修改人',
 `modify_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '最终修改时间',
 `is_delete` tinyint(2) DEFAULT '2' COMMENT '是否删除,1:是,2:否',
 PRIMARY KEY (`id`) USING BTREE,
 KEY `idx_business_ware` (`business_id`,`ware_inside_code`) USING BTREE
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 ROW_FORMAT=DYNAMIC COMMENT='商品销售统计';

SQL写法--行行比较

初始化数据

准备了769063条数据

SQL写法--行行比较

需求背景

业务机构下销售商品,同个业务机构可以销售不同的商品,同个商品可以在不同的业务机构销售,也就说:业务机构与商品是多对多的关系

假设现在有 n 个机构,每个机构下有几个商品,如何查询出这几个门店下各自商品的销售情况?

具体点,类似如下

SQL写法--行行比较

如何查出100001下商品1000、1001、1003100002下商品1003、1004100003下商品1006、1008、1009的销售情况

相当于是双层列表(业务机构列表中套商品列表)的查询;业务机构列表和商品列表都不是固定的,而是动态的

那么问题就是:如何查询多个业务机构下,某些商品的销售情况

(问题经我一描述,可能更模糊了,大家明白意思了就好!)

循环查询

这个很容易想到,在代码层面循环业务机构列表,每个业务机构查一次数据库,伪代码如下:

SQL写法--行行比较

具体的 SQL 类似如下

SQL写法--行行比较

SQL 能走索引

SQL写法--行行比较

实现简单,也好理解,SQL 也能走索引,一切看起来似乎很完美

然而现实是:部门开发规范约束,不能循环查数据库

哦豁,这种方式只能放弃,另寻其他方式了

OR 拼接

通过MyBatis的动态 SQL功能,进行 SQL 拼接,类似如下

SQL写法--行行比较

具体的 SQL 类似如下

SQL写法--行行比较

SQL 也能走索引

SQL写法--行行比较

实现简单,也好理解,SQL 也能走索引,而且只查询一次数据库,貌似可行

唯一可惜的是:有点费 OR,如果业务机构比较多,那 SQL 会比较长

作为候选人之一吧,我们接着往下看

混查过滤

同样是利用Mybatis的动态 SQL,将business_id列表拼在一起、ware_inside_code拼在一起,类似如下

SQL写法--行行比较

具体的 SQL 类似如下

SQL写法--行行比较

SQL 也能走索引

SQL写法--行行比较

实现简单,也好理解,SQL 也能走索引,而且只查询一次数据库,似乎可行

但是:查出来的结果集大于等于我们想要的结果集,你品,你细品!

所以还需要对查出来的结果集进行一次过滤,过滤出我们想要的结果集

姑且也作为候选人之一吧,我们继续往下看

行行比较

SQL-92 中加入了行与行比较的功能,这样一来,比较谓词 = 、< 、> 和 IN 谓词的参数就不再只是标量值了,还可以是值列表了

当然,还是得用到Mybatis的动态 SQL,类似如下

SQL写法--行行比较

具体的 SQL 类似如下

SQL写法--行行比较

SQL 同样能走索引

SQL写法--行行比较

实现简单,SQL 也能走索引,而且只查询一次数据库,感觉可行

只是:有点不好理解,因为我们平时这么用的少,所以这种写法看起来很陌生

另外,行行比较是 SQL 规范,不是某个关系型数据库的规范,也就说关系型数据库都应该支持这种写法

来源:https://www.cnblogs.com/youzhibing/p/15101096.html

标签:SQL,行行比较
0
投稿

猜你喜欢

  • 一篇文章彻底弄懂Python中的if __name__ == __main__

    2023-04-27 08:42:14
  • Django视图、传参和forms验证操作

    2023-03-04 09:17:03
  • 如何将服务器上的python代码通过QQ发送回传信息(附实现方法)

    2022-04-24 04:27:08
  • python使用装饰器作日志处理的方法

    2021-08-17 03:20:32
  • Python3 扫描库文件并获取版本号信息的操作方法

    2023-08-11 19:14:17
  • 利用Tensorflow构建和训练自己的CNN来做简单的验证码识别方式

    2021-02-07 14:24:18
  • MySQL去重的方法整理

    2024-01-27 07:04:42
  • Python中self用法实例详解

    2022-12-18 08:27:48
  • python中matplotlib实现随鼠标滑动自动标注代码

    2023-09-02 10:49:47
  • vue使用iframe嵌入网页的示例代码

    2024-05-05 09:12:04
  • Python使用多进程运行含有任意个参数的函数

    2023-10-14 23:22:12
  • 如何在页面中快捷地添加翻页按钮?

    2010-06-26 12:33:00
  • python 实现学生信息管理系统的示例

    2021-05-01 01:37:24
  • 解密CSS Sprites:技巧、工具和教程

    2011-01-11 19:38:00
  • 使用 JScript 创建 .exe 或 .dll 文件

    2011-06-04 15:37:00
  • MySQL数据库中对前端和后台进行系统优化

    2009-01-04 13:39:00
  • python使用psutil模块获取系统状态

    2021-12-13 23:36:10
  • Python 数值区间处理_对interval 库的快速入门详解

    2022-08-12 00:18:53
  • 给页面加上Loading效果最简单实用的办法

    2008-11-20 11:58:00
  • Python中格式化字符串的四种实现

    2023-11-25 10:38:18
  • asp之家 网络编程 m.aspxhome.com