oracle 查找某字段中含有回车换行的记录,请问怎么写SQL?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了oracle 查找某字段中含有回车换行的记录,请问怎么写SQL?相关的知识,希望对你有一定的参考价值。

参考技术A 使用instr与chr函数可以解决你的问题,语句如下:
select * from 表名 where instr(列名, chr(10) > 0) or instr(列名,chr(13)) >;
instr(源字符串,
目标字符串,
起始位置,
匹配序号)
instr函数返回要截取的字符串在源字符串中的位置。
chr(ASCII码)函数将ASCII码转换为字符。

Oracle删除字段中的空格、回车及指定字符的实例代码

参考技术A 废话不多说了,直接给大家贴代码了,具体代码如下所示:
create
or
replace
procedure
PROC_test
is
--Description:删除字段中的指定字符(回车chr(13)、换行chr(10))
--By
LiChao
--Date:2016-03-01
colname
varchar(20);
--列名
cnt
number;
--包含换行符的列的行数
v_sql
varchar(2000);
--动态SQL变量
begin
--读取表中的列
for
col
in
(select
column_name
from
user_tab_columns
where
table_name
=
'TEMP')
loop
colname
:=
col.column_name;
--替换换行符chr(10)
v_sql
:=
'select
count(1)
from
temp
where
instr('
||
colname
||
',chr(10))>0
';
EXECUTE
IMMEDIATE
V_SQL
into
cnt;
if
cnt
>
0
then
v_sql
:=
'update
temp
set
'
||
colname
||
'=trim(replace('
||
colname
||
',chr(10),''''))'
||
'where
instr('
||
colname
||
',chr(10))>0
';
EXECUTE
IMMEDIATE
V_SQL;
commit;
end
if;
--替换回车符chr(13)
v_sql
:=
'select
count(1)
from
temp
where
instr('
||
colname
||
',chr(13))>0
';
EXECUTE
IMMEDIATE
V_SQL
into
cnt;
if
cnt
>
0
then
v_sql
:=
'update
temp
set
'
||
colname
||
'=trim(replace('
||
colname
||
',chr(13),''''))'
||
'where
instr('
||
colname
||
',chr(13))>0
';
EXECUTE
IMMEDIATE
V_SQL;
commit;
end
if;
--替换'|'
chr(124)
为'*'
chr(42)
v_sql
:=
'select
count(1)
from
temp
where
instr('
||
colname
||
',chr(124))>0
';
EXECUTE
IMMEDIATE
V_SQL
into
cnt;
if
cnt
>
0
then
v_sql
:=
'update
temp
set
'
||
colname
||
'=replace('
||
colname
||
',chr(124),chr(42))'
||
'where
instr('
||
colname
||
',chr(124))>0
';
EXECUTE
IMMEDIATE
V_SQL;
commit;
end
if;
end
loop;
end
PROC_test;
/
以上所述是小编给大家介绍的Oracle删除字段中的空格、回车及指定字符的实例代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

以上是关于oracle 查找某字段中含有回车换行的记录,请问怎么写SQL?的主要内容,如果未能解决你的问题,请参考以下文章

oracle 把某字段里面的特定字符,转换为回车换行符,请问怎么弄?

在oracle里如何去掉数据后的回车换行符

oracle换行符,落表时怎么存

Oracle删除字段中的空格、回车及指定字符的实例代码

请问notepad++如何将换行替换成其它符号?

sql 查询字段中包含回车 如何查出含有回车的字段