首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >使用SQL outer join进行分组但不进行聚合,而不进行排序

使用SQL outer join进行分组但不进行聚合,而不进行排序
EN

Stack Overflow用户
提问于 2018-06-10 04:24:50
回答 1查看 57关注 0票数 1

我有两张桌子foobar。对于每一个foo,都有零个或更多的条。做一个LEFT OUTER JOIN给我一个结果集就足够了,在这个结果集中,每一行都给我一个foo加上它的一个条(如果没有与foo关联的条,则为NULL )。

但是假设我想要所有的结果将foo分组在一起。请注意,我不希望它们聚合在一起;也就是说,我不希望所有的foo行都折叠每个主键。如果有一个带有主键foo123的foo,我只想让所有的foo123 foo一起出现。例如,我不希望有[foo123, foo123, foo456, foo123];我想要[foo123, foo123, foo123, foo456],甚至[foo456, foo123, foo123, foo123]

当然,我可以按foo主键进行排序,但排序似乎有点过分,因为我并不关心foo的顺序;只有具有相同ID的所有foo在结果集中“分组”在一起。

在SQL中有没有一种更有效的方法,可以根据一些标准将喜欢“分组在一起”,而不需要排序?

我正在使用Oracle,以防万一。

(不管怎样,我有一个“绝妙”的想法,就是将连接与相关子查询结合使用,以便为每个foo单独查找条形图,但是我忘记了在FROM子句中不能有相关子查询。)

EN

回答 1

Stack Overflow用户

发布于 2018-06-10 04:32:52

我不认为有任何方法可以可靠地做到这一点,除了:

代码语言:javascript
复制
ORDER BY foo.foo_primary_key

原因是,在没有ORDER BY的情况下,SELECT语句返回结果的顺序是未定义的。

在您的Oracle版本中,可能有一些方法可以在不使用ORDER BY的情况下以您想要的方式返回分组的结果--但是这种情况很容易发生意外的变化。依赖这样的解决方案是不明智的。

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50778230

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档