文档章节

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

北风刮的不认真了
 北风刮的不认真了
发布于 2017/05/13 17:51
字数 495
阅读 162
收藏 0

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或者省略CROSSJOIN,或者使用',' 如

SELECT * FROM table1 CROSS JOIN table2 
SELECT * FROM table1 JOIN table2 
SELECT * FROM table1,table2 

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

© 著作权归作者所有

北风刮的不认真了

北风刮的不认真了

粉丝 37
博文 53
码字总数 27105
作品 1
朝阳
后端工程师
私信 提问
【理论】离散数学中的二元关系

这篇文章将了解到以下方面的知识 01 二元关系的定义 02 笛卡尔积定义 03 二元关系的表示方式 0301 二元关系是笛卡尔积的子集 0302 等价关系与集合上的划分一一对应 二元关系定义 由两个元素x...

needrunning
2017/12/14
0
0
MongoDB Map-reduce 如何避免全局锁

在MongoDB中驱动分析的两个重要特性是: 聚合 Map-Reduce 一般来说大多数的聚合架构并不需要任何全局写锁,但是当把reducer(规约)结果写到现存的或新的结果集时,Map-Reduce则需要全局写锁。...

oschina
2014/04/06
1K
1
Mysql内连接、左连接会出现笛卡尔积的理解

先简单解释一下笛卡尔积。 现在,我们有两个集合A和B。 A = {0,1} B = {2,3,4} 集合 A×B 和 B×A的结果集就可以分别表示为以下这种形式: A×B = {(0,2),(1,2),(0,3),(1,3),...

文文1
05/25
145
0
MySQL的JOIN(一):用法

MySQL的JOIN(一):用法 JOIN的含义就如英文单词“join”一样,连接两张表,大致分为内连接,外连接,右连接,左连接,自然连接。这里描述先甩出一张用烂了的图,然后插入测试数据。 CREATE...

法斗斗
2018/01/30
44
0
【Mysql】Mysql的Join完全解读

一、用法 JOIN的含义就如英文单词“join”一样,连接两张表,大致分为内连接,外连接,右连接,左连接,自然连接。这里描述先甩出一张用烂了的图,然后插入测试数据。 用例表 1、笛卡尔积:C...

慕凌峰
2018/11/14
0
0

没有更多内容

加载失败,请刷新页面

加载更多

分布式协调服务zookeeper

ps.本文为《从Paxos到Zookeeper 分布式一致性原理与实践》笔记之一 ZooKeeper ZooKeeper曾是Apache Hadoop的一个子项目,是一个典型的分布式数据一致性的解决方案,分布式应用程序可以基于它...

ls_cherish
今天
4
0
redis 学习2

网站 启动 服务端 启动redis 服务端 在redis 安装目录下 src 里面 ./redis-server & 可以指定 配置文件或者端口 客户端 在 redis 的安装目录里面的 src 里面 ./redis-cli 可以指定 指定 连接...

之渊
昨天
2
0
Spring boot 静态资源访问

0. 两个配置 spring.mvc.static-path-patternspring.resources.static-locations 1. application中需要先行的两个配置项 1.1 spring.mvc.static-path-pattern 这个配置项是告诉springboo......

moon888
昨天
4
0
hash slot(虚拟桶)

在分布式集群中,如何保证相同请求落到相同的机器上,并且后面的集群机器可以尽可能的均分请求,并且当扩容或down机的情况下能对原有集群影响最小。 round robin算法:是把数据mod后直接映射...

李朝强
昨天
4
0
Kafka 原理和实战

本文首发于 vivo互联网技术 微信公众号 https://mp.weixin.qq.com/s/bV8AhqAjQp4a_iXRfobkCQ 作者简介:郑志彬,毕业于华南理工大学计算机科学与技术(双语班)。先后从事过电子商务、开放平...

vivo互联网技术
昨天
24
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部