mysql 中使用笛卡尔积 避免其中一方为空集时结果就是空集的方法
2017-05-13 17:51
148 查看
mysql 里 笛卡尔积在实际开发中很少遇到,今天我是想将多个不同的select的结果(每个select的集合大小都是1或者0)只用一次查询返回在同一行中,但发现个问题,当其中一个结果集为空集时,最终结果就是空集.
我确保里面每个子查询寻的结果条数都是1或0.但是当里面其中一个是0时,就都没了.
改用
问题来了,t1的结果条数是0怎么办.....
需要有个必须能查出的结果.
这回就不会存在没有返回的情况了.
如
由于其返回的结果为被连接的两个数据表的乘积,因此当有WHERE, ON或USING条件的时候一般不建议使用,因为当数据表项目太多的时候,会非常慢。
一般使用
开始用的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
相关文章推荐
- Delphi 中使用 ADO 方法打开 MySQL5.0 数据库并避免汉字乱码
- 关于mysql 数据库使用spring 2.0低版本 JdbcTemplate.queryForList 查询结果别名不起作用的解决方法
- MySQL避免使用swap分区的方法
- Delphi 中使用 ADO 方法打开 MySQL5.0 数据库并避免汉字乱码
- PHP使用mysql_fetch_object从查询结果中获取对象集的方法
- SQL中条件和比较关键字Case的使用方法(case的结果就是得到了一个值)
- 避免重复入库的插入记录方法-----mysql 使用记号
- 正确使用MySQL JDBC setFetchSize()方法解决JDBC处理大结果
- MySQL避免使用swap分区的方法
- MySQL避免使用swap分区的方法
- Delphi 中使用 ADO 方法打开 MySQL5.0 数据库并避免汉字乱码
- SQL中条件和比较关键字Case的使用方法(case的结果就是得到了一个值)
- 我在一个前端项目中用js整理的一些通用方法,其中使用到的思想,主要就是约定了。
- MySQL中的字符集涵义及使用方法总结(一)
- spring hibernate mysql 使用中的问题及解决方法
- mysql免安装版使用方法
- MySQL安装笔记和一些使用方法
- 使页面立即过期?就是避免使用ie的后退键?
- 使用Dojo实现页面不刷新提交数据时避免前台缓存的方法
- 让Funambol(sync4j)使用mysql的最简方法