首页 > 解决方案 > 将sql join的2个结果合并为一个结果

问题描述

我正在执行一项任务,我需要以以下格式获取和显示 postgres 数据库数据。

在此处输入图像描述

我正在尝试的查询是,

select fv.integer_value as source_id, fv.string_value as source_name, p.amount as amount from payment p 
    INNER join user u on p.user_id = u.id  
        INNER join customer c on u.id = c.user_id
        INNER JOIN customer_field_map cfm ON cfm.customer_id = c.id
        INNER JOIN field_value fv ON cfm.field_value_id = fv.id
        INNER JOIN field_name fn ON fn.id = fv.field_name_id
        WHERE fn.name in ('source_id', 'source_name')
    group by source_id, source_name, amount;

field_value 表结构是这样的,

field_value (
    id,
    field_name_id,
    integer_value,
    String_value
)

考虑以下分布在user等表中的用户记录field_namefield_value

user_id  source_id   source_name   amount
10        100         source-1      100

对于上面的记录,上面的 sql 查询给了我 2 个结果,比如,

在此处输入图像描述

任何建议如何实现所需的结果并将 2 个结果合并为一个,如开头的图像所示。

source_id 和 source_name 组合不会变化,但多个用户可以有相同的组合。

编辑

详细的表格结构和示例数据在以下几行,

user (
id integer,
user_name character varying (100)
)

id    name
------------------------
100  test-name

customer (
id integer,
user_id integer
)

id      user_id
------------------------
100     100

payment (
 id integer,
 user_id integer,
 amount numeric
)

id      user_id   amount
------------------------
100     100       100


field_name (
 id integer,
 name character varying (100)
)

id      name
------------------------
100     source_id
101     source_name

field_value (
    id,
    field_name_id,
    integer_value,
    String_value
)

id      name     integer_value     string_value   
----------------------------------------------------
100     100       101             null  
101     101       null            source-1


customer_field_map (
   customer_id integer,
   field_value_id integer  
)

customer_id     field_value_id
----------------------------------------------------
100              100
100              101 

标签: sqlpostgresqljoin

解决方案


您的逻辑有点难以理解,因为您的查询返回三列,但数据有四列。

如果您希望每个用户一行,那么group by应该只包含一个键 -- u.id。所以:

select u.id, max(fv.integer_value) as source_id,
       max(fv.string_value) as source_name, p.amount as amount
from payment p join
     user u
     on p.user_id = u.id join
     customer c 
     on u.id = c.user_id join
     customer_field_map cfm 
     on cfm.customer_id = c.id join
     field_value fv 
     on cfm.field_value_id = fv.id join
     field_name fn ON fn.id = fv.field_name_id 
where fn.name in ('source_id', 'source_name')
group by u.id;

推荐阅读