我有一个有四行的表。
column1 | column2 | column3
---------------------------
a | role | N/A
b | N/A | N/A
c | N/A | year
c | year | N/A
有没有办法在select语句中得到像
这样的结果column1 | column2 | column3
---------------------------
a | role | can be N/A or null
c | year | year
忽略N/A
。
感谢。
答案 0 :(得分:1)
您可以使用聚合:
select column1, max(nullif(column2, 'N/A')) as column2,
max(nullif(column3, 'N/A')) as column3
from t
group by column1;
我意识到这是假设第二行中的column1
值实际上是“a”而不是“b”。
答案 1 :(得分:1)
戈登的查询需要额外的过滤器:
select *
from (
select
column1,
max(nullif(column2, 'N/A')) as column2,
max(nullif(column3, 'N/A')) as column3
from a_table
group by 1
) s
where column2 notnull or column3 notnull
order by 1;
column1 | column2 | column3
---------+---------+---------
a | role |
c | year | year
(2 rows)