1
saulshao 2018-08-23 21:42:55 +08:00
如果是我,会考虑放大条件,将数据读到内存里按照业务逻辑来处理。
用拼 SQL 的方法如果你是用程序拼出来的,会非常麻烦,还可能会拼出来长度无法预计的 SQL。 |
2
msg7086 2018-08-24 00:30:10 +08:00
搜出来以后放在程序里计算啊。
又不是银行电信,没必要把业务逻辑都放在数据库层吧。 实际开发中,数据库一般是中心单点,程序可以在外围跑多个。 你把业务全交给本来就很孤独的数据库,进一步加重其负担,何必呢。 |
3
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 |
4
iblessyou OP |