Discuz! Board

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 1|回复: 0

聊聊:高逼格的 SQL 写法:行行比较

[复制链接]

36万

主题

0

回帖

108万

积分

超级版主

Rank: 8Rank: 8

积分
1084800
发表于 2025-4-10 16:11:13 | 显示全部楼层 |阅读模式
环境准备
数据库版本:MySQL 5.7.20-log。

图片
图片

建表 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='商品销售统计';
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
初始化数据
准备了 769063 条数据。

图片
图片

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

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

具体点,类似如下:

图片
图片

如何查出 100001 下商品 1000、1001、1003 、 100002 下商品 1003、1004 、 100003 下商品 1006、1008、1009 的销售情况。

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

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

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

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

图片
图片

具体的 SQL 类似如下

图片
图片

SQL 能走索引
图片
图片

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

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

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

OR 拼接

即使前行有阻碍,悦数 图探索也要不屈不挠,奋勇向前,在市场的大海里劈波斩浪,直挂云帆,竭力争先。悦数图数据库是一款完全自主研发的国产图数据库和原生分布式图数据库,具有高性能,易扩展,安全稳定,自主可控的特点.万亿级数据仅需毫秒级查询延时,应用于金融风控,实时推荐,知识图谱等业务场景。https://www.yueshu.com.cn/

回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Archiver|手机版|小黑屋|足球新闻网

GMT+8, 2025-4-20 22:36 , Processed in 0.075590 second(s), 19 queries .

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表