V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
iblessyou
V2EX  ›  程序员

求解一个简单的 SQL 问题

  •  
  •   iblessyou · 2018-08-23 19:02:36 +08:00 · 1854 次点击
    这是一个创建于 2287 天前的主题,其中的信息可能已经有所发展或是发生改变。
    数据库是 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 ……

    求解有什么简单办法没
    5 条回复    2018-08-24 10:20:18 +08:00
    saulshao
        1
    saulshao  
       2018-08-23 21:42:55 +08:00
    如果是我,会考虑放大条件,将数据读到内存里按照业务逻辑来处理。
    用拼 SQL 的方法如果你是用程序拼出来的,会非常麻烦,还可能会拼出来长度无法预计的 SQL。
    msg7086
        2
    msg7086  
       2018-08-24 00:30:10 +08:00
    搜出来以后放在程序里计算啊。
    又不是银行电信,没必要把业务逻辑都放在数据库层吧。
    实际开发中,数据库一般是中心单点,程序可以在外围跑多个。
    你把业务全交给本来就很孤独的数据库,进一步加重其负担,何必呢。
    wanganjun
        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
    iblessyou
        4
    iblessyou  
    OP
       2018-08-24 10:12:46 +08:00
    @saulshao @msg7086 因为这个功能虽然条件多,但表数据很少,一般也就几十,最多几百条数据吧,又是个简单的功能,用的也不会很多。
    当然,也有自己的习惯,目前还是个初开,做事首先还是想到用自己习惯的方式做了,以后会注意的
    iblessyou
        5
    iblessyou  
    OP
       2018-08-24 10:20:18 +08:00
    @wanganjun 看了下网页,太感谢了,虽然已经用我想的方法先把任务做了,也学到一个新技能 ヽ(✿゚▽゚)ノ
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   5492 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 28ms · UTC 07:46 · PVG 15:46 · LAX 23:46 · JFK 02:46
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.