oracle 如果我在查询出来的结果中每一列的值为1,2 我要根据条件只显示一个值怎么处理
列如:查询出来的结构有这么两列列1列21a,d1null2b,c2b,c2null3a,c现在在列2中,a与b属于类1、c与d属于类2,而且类1中a与b不会出现共存的现象...
列如: 查询出来的结构有这么两列
列1 列2
1 a,d
1 null
2 b,c
2 b,c
2 null
3 a,c
现在在列2中,a与b属于类1、c与d属于类2,而且类1中a与b不会出现共存的现象,在列1相同的情况下,列2的结果只会有null和相同的值的情况。
我只将类1的值a保留下来,并且要将值为null的赋值为与之列相同的类1,如第二行中的null赋值显示为a,第五行中的null赋值显示为b,但是都不更新数据库数据,只为了查询出结果。 展开
列1 列2
1 a,d
1 null
2 b,c
2 b,c
2 null
3 a,c
现在在列2中,a与b属于类1、c与d属于类2,而且类1中a与b不会出现共存的现象,在列1相同的情况下,列2的结果只会有null和相同的值的情况。
我只将类1的值a保留下来,并且要将值为null的赋值为与之列相同的类1,如第二行中的null赋值显示为a,第五行中的null赋值显示为b,但是都不更新数据库数据,只为了查询出结果。 展开
展开全部
用case和正则表达式可以处理,不知道列1的值为3时怎么处理,所以我没处理,你可以自己修改。
with t as
( select 1 col1, 'a,d' col2 from dual
union all
select 1, null from dual
union all
select 2, 'b,c' from dual
union all
select 2, 'b,c' from dual
union all
select 2, null from dual
union all
select 3, 'a,c' from dual
)
select col1, case when col1 = 1
then case when col2 is null then 'a'
when col2 is not null then regexp_substr(col2,'([a-b])')
else col2 end
when col1 = 2
then case when col2 is null then 'b'
when col2 is not null then regexp_substr(col2,'([c-d])')
else col2 end
else col2 end
from t;
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询