『MySQL』行号关联查询

在这里插入图片描述

前言

永远相信美好的事情即将发生


背景

前段时间碰到过这样一个问题,查询出一家店铺在2020年和2019年活动类型为’xxx’的日期,因历史原因,2019年的活动和2020年的活动分别存储在两张表中,需要通过外连接将查询结果放在一起展示,最终要的结果大概长这样:

2019年日期2019年活动2020年日期2020年活动
2019/01/05xxx节2020/02/01xxx节
2019/03/12xxx节2020/04/10xxx节
2019/07/19xxx节2020/06/05xxx节
2020/09/09xxx节
2020/12/15xxx节

踩坑

刚接手需求的时候,我的内心是这样的

在这里插入图片描述
我祭出我小学5年级的SQL功底,通过费马定理,泰勒公式,拉格朗日定理以及洛必达法则,再结合我眼花缭乱的一指禅打字技术,终于不负众望的没写出来

在这里插入图片描述
问题的原因是什么呢,单独查询2019年活动类型为’xxx’的日期很简单,单独查询2020年活动类型为’xxx’的日期也很简单,那么关联条件呢?肯定会有憨憨说用店铺id关联啊,或者说用活动类型关联啊

在这里插入图片描述
左边的查询结果和右边的查询结果已经查询出了这家店铺分别在2020年和2019年活动类型为’xxx’的日期,无论是通过店铺id还是活动类型关联都会做笛卡尔积,所以需要另寻其他关联条件

解决

抱着不耻下问,不对,是不耻上问的学习态度,请教了我们的老大,当时的情景大概是这样

在这里插入图片描述大佬给我指了条明路,行号关联查询,然后亲自指导了一番,在大牛的光辉照耀以及我的不懈努(bai)力(du)下,我终于不负众望的写了出来,SQL简化后大体如下:

SELECT
	* 
FROM
	( 
	SELECT 
		@rownuma := @rownuma + 1 AS num_1, table_a.* 
	FROM table_a, 
	( SELECT @rownuma := 0 ) 
	) a
	LEFT JOIN ( 
	SELECT 
		@rownumb := @rownumb + 1 AS num_2, table_b.* 
	FROM table_b, 
	( SELECT @rownumb := 0 ) 
	) b ON a.num_1 = b.num_2

给左边的查询结果和右边的查询结果分别添加一个行号,行号都是从1开始,这样就可以做到左边的数据集和右边的数据集进行关联,但是

在这里插入图片描述
当左边结果集的行数小于等于右边的结果时,这种写法没有任何的问题,那么当右边的结果集行数大于左边呢,没错,它只能显示和左边行数一样的部分,那么问题来了,当左右结果集行数不确定的时候怎么办呢?没错,使用union连接一下左外连接和右外连接的结果集就o的k了

SELECT
	* 
FROM
	( 
	SELECT 
		@rownuma := @rownuma + 1 AS num_1, table_a.* 
	FROM table_a, 
	( SELECT @rownuma := 0 ) 
	) a
	LEFT JOIN ( 
	SELECT 
		@rownumb := @rownumb + 1 AS num_2, table_b.* 
	FROM table_b, 
	( SELECT @rownumb := 0 ) 
	) b ON a.num_1 = b.num_2
	UNION
	SELECT
	* 
FROM
	( 
	SELECT 
		@rownumc := @rownumc + 1 AS num_1, table_a.* 
	FROM table_a, 
	( SELECT @rownumc := 0 ) 
	) a
	RIGHT JOIN ( 
	SELECT 
		@rownumd := @rownumd + 1 AS num_2, table_b.* 
	FROM table_b, 
	( SELECT @rownumd := 0 ) 
	) b ON a.num_1 = b.num_2

注意点

使用行号名的时候切记不要使用相同的名称,应该像这样

在这里插入图片描述如果使用了相同的名称,你会发现关联之后的结果集某一列一开始会有很多的空白,别问我为什么知道,以前有一个憨憨就这样被坑了半天还不知道原因

在这里插入图片描述

总结

实际开发中碰到这种类似无规则关联的情景其实也比较少,但由于MySQL中缺少很多SQL关联的方法,就导致需要想点其他的方法去解决,希望各位看了我的踩坑之旅后能少踩点雷。

与诸君共勉

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

3价Fe离子

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值