您的位置:首页 > 数据库

union all 和where条件一起使用查询数据不对的问题

2017-11-03 16:33 344 查看
最近写sql的时候,需要两张表结合一起查询数据,并且根据条件从查询到的数据中只取一条,结果没有取到数据。

表一 test1

idname
1张三
2李四
3王五
表二 test2

idname
4小一
5小二
6小三
查询语句是这样的:

select id ,name from test1
union
select id, name from test 2  where id = 4
limit 1


这个sql的目的是,从两张表中,取出id = 4 的数据,如果有多条,只取一条。

但是查询结果是:

idname
1张三
经过分析发现,这条sql等效于下面:

select id ,name from test1
union (
select id, name from test 2  where id = 4 )
limit 1


这条sql(下面这个),查询结果是:

select id ,name from test1
union (
select id, name from test 2  where id = 4 )


idname
1张三
2李四
3王五
4小一
然后limit 1, 取出来的就是第一条,即张三-1

所以这条sql应该修改成下面:

第一种修改方式:

select id ,name from test1 where id = 4
union
select id, name from test 2  where id = 4
limit 1


第二种修改方式:

select t.* from (
select id ,name from test1
union
select id, name from test 2
) t where t.id = 4
limit 1


这两种修改方式都能正确查询到结果。

记录一下,防止后面再犯这种错误。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  sql
相关文章推荐