mysql中什么是空集合_mysql 中使用笛卡尔积 避免其中一方为空集时结果就是空集的方法...

在MySQL开发中,处理笛卡尔积和空结果集的情况是常见的挑战。本文介绍了如何通过LEFT JOIN解决这个问题,确保即使在子查询结果为空时,也能返回预期的数据。作者分享了一种使用LEFT JOIN的方法,通过与一个始终返回1的常量表连接,确保至少有一个结果。同时,讨论了笛卡尔积的效率问题,建议在有WHERE, ON或USING条件时避免使用,以防止数据量过大的情况。
摘要由CSDN通过智能技术生成

mysql 里 笛卡尔积在实际开发中很少遇到,今天我是想将多个不同的select的结果(每个select的集合大小都是1或者0)只用一次查询返回在同一行中,但发现个问题,当其中一个结果集为空集时,最终结果就是空集.

开始用的sql语句

SELECT * FROM

(select * from table1 ) as t1,

(select * from table2 ) as t2,

(select * from table3 ) as t3

我确保里面每个子查询寻的结果条数都是1或0.但是当里面其中一个是0时,就都没了.

改用left join 试试

SELECT * FROM

(select * from table1 ) as t1

left join

(select * from table2 ) as t2 on 1=1

left join

(select * from table3 ) as t3 on 1=1

问题来了,t1的结果条数是0怎么办.....

需要有个必须能查出的结果.

最终版

SELECT * FROM

(select 1) as t0 left join

(select * from table1 ) as t1 on 1=1

left join

(select * from table2 ) as t2 on 1=1

left join

(select * from table3 ) as t3 on 1=1

这回就不会存在没有返回的情况了.

笛卡尔积(交叉连接) (以下是copy的,忘记在那copy的了):

在MySQL中可以为CROSS JOIN或者省略CROSS即JOIN,或者使用',' 如

SELECT * FROM table1 CROSS JOIN table2

SELECT * FROM table1 JOIN table2

SELECT * FROM table1,table2

由于其返回的结果为被连接的两个数据表的乘积,因此当有WHERE, ON或USING条件的时候一般不建议使用,因为当数据表项目太多的时候,会非常慢。 一般使用LEFT [OUTER] JOIN或者RIGHT [OUTER] JOIN

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值