求oracle替换字段内容之SQL语句

我想请问下,求oracle替换字段内容之SQL语句
最新回答
紫南

2024-11-27 10:02:28

你是要在一个查询里,一次查询出但凡是字段值重复的列,不知道我是否理解正确了。
select
t.字段1,''
字段2,...,''
字段n
from
t1
t
group
by
t.字段1
having
count(t.字段1)>1
union
all
select
''
字段1,t.字段2,...,''
字段n
from
t1
t
group
by
t.字段2
having
count(t.字段2)>1
union
all
...
union
all
select
''
字段1,''
字段2,...,t.字段n
from
t1
t
group
by
t.字段n
having
count(t.字段n)>1;
梦沫惜

2024-11-27 08:38:26

你的意思是把后面括号里的日期都去掉?
只留某某公司
这样的话替换函数貌似没办法替换
只能截取
select
substr(a,1,instr(a,'(',1))
from

看看可以不
理想

2024-11-27 08:25:44

1、需要用到两个字符类函数instr和substr,具体用法介绍如下:
函数:字符定位函数
instr
语法:instr(待处理的字符串,需要查找的字符,开始查找的起始位置,第n次出现)
返回值:字母所在的位置,没有返回
0;
函数:字符定位函数
substr
语法:substr('要切割的值',从第几个位置开始切割,切割几位);
返回值:截取的字符串。
2、该题实现步骤,以字段A内容为'武汉一一科技公司(2009年2月注销)'为例:
第一步:先从字段A的字段第一个字符往前找左括号'('
第一次出现的位置,如下:
select
instr('武汉一一科技公司(2009年2月注销)',
'(',
1,
1)
--
9
from
dual;
第二步:从字段第一个字符开始,一直找出左括号'('的前一位就行,如下:
select
substr('武汉一一科技公司(2009年2月注销)',
1,
instr('武汉一一科技公司(2009年2月注销)',
'(',
1,
1)
-
1)
from
dual;
注:如果某某公司名称本身可能含有括号的话,建议从最后一个字符倒着往回找左括号出现第一次的位置,即
select
instr('武汉一一科技公司(2009年2月注销)',
'(',
-1,
1)
--
9
from
dual;
3、最终答案
select
select
substr(A,
1,
instr(A,
'(',
-1,
1)
-
1)
from
table
;