求解一个简单的 SQL 问题

2018-08-23 19:02:36 +08:00
 iblessyou
数据库是 postgresql
我现在有如下的表
name value
A 1
A 2
B 1

想取满足同 name 下 value 有在数组 1 ( 1,3,4 )里的 , 也有在数组 2 ( 2,3,4 )里的 name
这样的数组可能还有不定数量个。
很明显按 A 分组,然后行转列,变成 A (1,2) 和 B (1)判断是否和每个数组都有交集。得出 A 符合条件
但是不会操作 ╮(╯▽╰)╭
目前是用 value in ( 1,3,4 ) 和一条 sql,和另一条 value in ( 2,3,4 )的 sql 去 join
结果就是有多少条件就是多少 join ……

求解有什么简单办法没
1842 次点击
所在节点    程序员
5 条回复
saulshao
2018-08-23 21:42:55 +08:00
如果是我,会考虑放大条件,将数据读到内存里按照业务逻辑来处理。
用拼 SQL 的方法如果你是用程序拼出来的,会非常麻烦,还可能会拼出来长度无法预计的 SQL。
msg7086
2018-08-24 00:30:10 +08:00
搜出来以后放在程序里计算啊。
又不是银行电信,没必要把业务逻辑都放在数据库层吧。
实际开发中,数据库一般是中心单点,程序可以在外围跑多个。
你把业务全交给本来就很孤独的数据库,进一步加重其负担,何必呢。
wanganjun
2018-08-24 09:53:59 +08:00
```SQL
select name
from (
select name, array_agg(distinct(value)) as values
from 表名
group by name
) t
where (values && 数组 1) and (values && 数组 2) and ...
```


https://www.postgresql.org/docs/10/static/functions-array.html
iblessyou
2018-08-24 10:12:46 +08:00
@saulshao @msg7086 因为这个功能虽然条件多,但表数据很少,一般也就几十,最多几百条数据吧,又是个简单的功能,用的也不会很多。
当然,也有自己的习惯,目前还是个初开,做事首先还是想到用自己习惯的方式做了,以后会注意的
iblessyou
2018-08-24 10:20:18 +08:00
@wanganjun 看了下网页,太感谢了,虽然已经用我想的方法先把任务做了,也学到一个新技能 ヽ(✿゚▽゚)ノ

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/482626

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX