首页 > 2 个查询结果集怎么合并?

2 个查询结果集怎么合并?

表结构
a:

aid

b:

aid name

x:

xid

y:

xid aid value

SELECT a.aid,b.name FROM a join b on a.aid = b.aid

aid name
1 aaaa

SELECT x.aid,y.value FROM x join y on x.xid = y.xid

aid value
1 bbb

想得到结果,因为上面2个结果都有aid。

aid name value
1 aaa bbb

如果你是想在查询时“合并”可以用关联(JOIN),如果你是指已经取得了数据集想用程序实现关联,如果是 Python 推荐用 Pandas,Java 可参考我的 https://github.com/ihongs/HongsCORE/blob/develop/src/java/app/hongs/db/FetchMore.java 中的部分代码(join),或者搜索其他实现。程序关联方法之一介绍:查询第一张表的数据,提取外键和行号(或行对象)组成映射,用外键为条件去查关联表,遍历结果或映射,追加到前面的数据中;依次关联其他表的结果。


把你的两条sql: SELECT a.aid,b.name FROM a join b on a.aid = b.aidSELECT x.aid,y.value FROM x join y on x.xid = y.xid 继续作为子语句,连接起来。如果是等值连接只需要取其中一个的aid值就行了。 full join 可以用case语句进行选择

等值连接示例:

select tmpa.aid, tmpa.name, tmpb.value from 
   (SELECT a.aid,b.name FROM a join b on a.aid = b.aid ) tmpa 
    inner join (SELECT x.aid,y.value FROM x join y on x.xid = y.xid) tmpb
    on tmpa.aid=tmpb.aid

看到表结构的时候,直接就可以:
SELECT b.aid, b.name, y.value FROM b INNER JOIN y ON b.aid = y.aid;

然后如果题主确实是要连接a表和x表的话,跟前面的回答是正确的,不过sql有一两个小地方没写对:
SELECT tmpa.aid, tmpa.name, tmpb.value FROM
(SELECT a.aid,b.name FROM a JOIN b ON a.aid = b.aid) tmpa
INNER JOIN
(SELECT x.xid,y.aid,y.value FROM x JOIN y ON x.xid = y.xid) tmpb
ON tmpa.aid=tmpb.aid;

【热门文章】
【热门文章】