oracle怎么将字符串中的转义符
在ORACLE中,单引号有两个作用: 1:字符串是由单引号引用 2:转义。 单引号的使用是就近配对,即就近原则。而在单引号充当转义角色时相对不好理解1.从第二个单引号开始被视为转义符,如果第二个单引号后面还有单引号(哪怕只有一个)。
目前创新互联已为千余家的企业提供了网站建设、域名、网页空间、网站托管、企业网站设计、黎平网站维护等服务,公司将坚持客户导向、应用为本的策略,正道将秉承"和谐、参与、激情"的文化,与客户和合作伙伴齐心协力一起成长,共同发展。
oracle 怎么转义
在字段里查找'%',涉及到Oracle的转义字符,现总结如下:
SQL select * from test;
TEST
--------------------
sdd_kk
d'd
dfsfsa
dffa%asfs
12345
1%2345
1%54321
2%54321
%%54321
AB
已选择9行。
其中包含特殊的字符分别为%,_,,有可能包含这些字符的数据含有错误,或者需要查找包含这些字符的数据。
SQL select * from test where test like 'sdd _%' escape ' ';
TEST
--------------------
sdd_kk
转义字符为' ';
SQL select * from test where test like 'sdd\_%' escape '\';
TEST
--------------------
sdd_kk
转义字符为'\';
SQL select * from test where test like 'sdd=_%' escape '=';
TEST
--------------------
sdd_kk
转义字符为'=';
SQL select * from test where test like 'sdd/_%' escape '/';
TEST
--------------------
sdd_kk
转义字符为'/';
SQL select * from test where test like 'sddd_%' escape 'd';
未选定行
转义字符为d,没有实现转义功能;
SQL select * from test where test like '%\_%' escape '\';
TEST
--------------------
sdd_kk
查找包含所有'_'的字段。
同理:通过这种方法查找含有'%'的所有字段:
SQL select * from test where test like '%\%%' escape '\';
TEST
--------------------
dffa%asfs
1%2345
1%54321
2%54321
%%54321
但是''不能通过转义字符查找:
SQL select * from test where test like '%\%' escape'\';
select * from test where test like '%\%' escape'\'
*
第 1 行出现错误:
ORA-01424: 转义符之后字符缺失或非法
可以通过另外的方式进行转义:
SQL select ascii('') from dual;
ASCII('')
----------
38
SQL select * from test where test like '%'||chr(38)||'%';
TEST
--------------------
AB
'''的转义:
SQL select * from test where test like '%''%';
TEST
--------------------
d'd
特殊符号的数据的插入
SQL insert into test values('testtest');
输入 test 的值: test
原值 1: insert into test values('testtest')
新值 1: insert into test values('testtest') -虽然插入,但是数据不对。
已创建 1 行。
SQL show define
define "" (hex 26)
SQL set define off
SQL show define
define OFF
SQL insert into test values('testtest');
已创建 1 行。
SQL show escape
escape OFF
SQL set escape on
SQL show escape
escape "\" (hex 5c)
SQL insert into test values('test\test');
已创建 1 行。
SQL select * from test;
TEST
--------------------
sdd_kk
d'd
dfsfsa
dffa%asfs
12345
1%2345
1%54321
2%54321
%%54321
AB
testtest
TEST
--------------------
testtest
testtest
已选择13行。
SQL commit;
提交完成。
SQL select * from test;
TEST
--------------------
sdd_kk
d'd
dfsfsa
dffa%asfs
12345
1%2345
1%54321
2%54321
%%54321
AB
testtest
TEST
--------------------
testtest
testtest
已选择13行。
SQL insert into test values('test\%test');
已创建 1 行。
SQL insert into test values('test\_test');
已创建 1 行。
SQL insert into test values('test\'test);
insert into test values('test'test)
*
第 1 行出现错误:
ORA-00917: 缺失逗号
SQL insert into test values('test''test');
已创建 1 行。
SQL select * from test;
TEST
--------------------
sdd_kk
d'd
dfsfsa
dffa%asfs
12345
1%2345
1%54321
2%54321
%%54321
AB
testtest
TEST
--------------------
testtest
testtest
test%test
test_test
test'test
已选择16行。
oracle replace 函数如何改写带有引号和逗号的值
select replace('A','A','''A'',''B''') from dual
不知道这种效果是不是你想要的。上边是我测试的sql。将A替换为'A','B'
如果将'A'替换为'A','B' 应该是 replace('A','''A''','''A'',''B''')
' 在oracle中需要使用''来转义。
Oracle 语句如何转义
begin
dbms_output.put_line('''abcd''');
end;
oracle中字符串中,单引号用两个单引代表一个,也就是说单引号本身是转义符
标题名称:oracle怎么转译逗号 oracle以逗号分隔
链接分享:http://scgulin.cn/article/hjchci.html