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,但是都不更新数据库数据,只为了查询出结果。
展开
 我来答
百度网友e415e6e
推荐于2017-12-16 · TA获得超过136个赞
知道小有建树答主
回答量:141
采纳率:100%
帮助的人:150万
展开全部

用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;
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式