您的位置:首页 > 数据库 > MySQL

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

2017-05-13 17:51 148 查看
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
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: