我正在尝试使用以下查询以列表形式检索race_code、chara_code 和reason_code:
SELECT a.pid,
LISTAGG(a.rc, ',') WITHIN GROUP (ORDER BY a.rc) AS race,
LISTAGG(a.cc, ',') WITHIN GROUP (ORDER BY a.cc) as chara_codes,
LISTAGG(a.rrc, ',') WITHIN GROUP (ORDER BY a.rrc) AS removal_reason
FROM (
SELECT UNIQUE
p.person_id pid,
r.race_code rc,
c.characteristic_code cc,
rr.removal_reason_code rrc
FROM person p left outer join race r on p.person_id = r.person_id
left outer join characteristic c on p.person_id = c.person_id
left outer join placement_episode pe on p.person_id = pe.child_id
left outer join removal_reason rr on pe.placement_episode_id = rr.placement_episode_id
) a
GROUP BY a.pid
Run Code Online (Sandbox Code Playgroud)
我在引用一些链接(如link1和link2 )后尝试了此查询。但这样做之后我也无法获得所有字段的唯一值。
我的 o/p 是这样的:
pid race_code chara_code reason_code
1 a,b,b,c c1,c1,c2,c3 r1,r2,r3,r3
2 a,c,d,d,d c1,c2,c2 r3,r3
and so on.
Run Code Online (Sandbox Code Playgroud)
如果我尝试一次仅检索一个字段并保留所需的连接操作,那么它会给出正确的结果。但对于多个 LISTAGG() 函数,其重复值。
我没有办法做到这一点。还有其他方法可以获得不同的值吗?
不幸的是,这比需要的更复杂。但是,你可以做到。这个想法是枚举每个值,然后使用将参数case传递给.NULLLISTAGG()
SELECT a.pid,
LISTAGG(CASE WHEN rc_seqnum = 1 THEN a.rc END, ',') WITHIN GROUP (ORDER BY a.rc) AS race,
LISTAGG(CASE WHEN cc_seqnum = 1 THEN a.cc END, ',') WITHIN GROUP (ORDER BY a.cc) as chara_codes,
LISTAGG(CASE WHEN rrc_seqnum = 1 THEN a.rrc END, ',') WITHIN GROUP (ORDER BY a.rrc) AS removal_reason
FROM (SELECT p.person_id as pid, r.race_code as rc, c.characteristic_code as cc,
rr.removal_reason_code as rrc,
row_number() over (partition by p.person_id, r.race_code order by r.race_code) as rc_seqnum,
row_number() over (partition by p.person_id, c.characteristic_code order by c.characteristic_code) as cc_seqnum,
row_number() over (partition by p.person_id, rr.removal_reason_code order by rr.removal_reason_code) as rrc_seqnum
FROM person p left outer join race r on p.person_id = r.person_id
left outer join characteristic c on p.person_id = c.person_id
left outer join placement_episode pe on p.person_id = pe.child_id
left outer join removal_reason rr on pe.placement_episode_id = rr.placement_episode_id
) a
GROUP BY a.pid;
Run Code Online (Sandbox Code Playgroud)
该查询根据每个人和字段组合枚举行。第一次看到该值时,它的值为“1”,后续值逐渐增加。onlyLISTAGG()选择第一个值。
您应该了解分析函数。它们非常有用。
| 归档时间: |
|
| 查看次数: |
3624 次 |
| 最近记录: |