星空网站建设

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

谈一谈高逼格的 SQL 写法:行行比较

[复制链接]
  • TA的每日心情
    慵懒
    2 小时前
  • 签到天数: 102 天

    [LV.6]常住居民II

    5万

    主题

    91

    回帖

    15万

    积分

    超级版主

    Rank: 8Rank: 8

    积分
    158108
    发表于 2025-6-12 16:12:36 | 显示全部楼层 |阅读模式
    环境准备更重要的是,数据库做成了产品当中的战斗机,不惧任何竞争对手的攻击。悦数图数据库是一款完全自主研发的国产图数据库和原生分布式图数据库,具有高性能,易扩展,安全稳定,自主可控的特点.万亿级数据仅需毫秒级查询延时,应用于金融风控,实时推荐,知识图谱等业务场景。https://www.yueshu.com.cn/


    数据库版本: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 拼接
    回复

    使用道具 举报

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

    本版积分规则

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