oracle - Mysql查询,join空表时发生问题

查看:90
本文介绍了oracle - Mysql查询,join空表时发生问题的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

问 题

问题是这样的,用户表有一个记录,现在想用用户表join另一张计算出来的表,查询用户表的一个记录和另一张计算出来的表的所有记录。
但是这张计算得来的表有可能是空的,当它是空表的时候,最后的查询结果就只能是空值了

select * from user u1 join (select * from user where user.id=2) as u2 where u1.id=1;

比如以上这个sql语句,user表只有id为1的记录。查询出来是Empty set ,
怎么让它把id为1的记录取出来?

PS:试过左连接,,结果不行,报错了

select * from user u1 left join (select * from user where user.id=2) as u2 where u1.id=1;

在where u1.id=1附近出的错

解决方案

左连接是这样玩的么..

SELECT * FROM user LEFT JOIN user2 ON user1.id = user2.gid where 你的条件

以左表为基准,右表没数据也会返回左表的内容

SELECT * FROM table1 JOIN table2 
条件没有直接这样

这篇关于oracle - Mysql查询,join空表时发生问题的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆