在oracle中的转义字符:1、单引号,用于引用字符串或对自身转义;2、双引号,用于将非法的格式符包装起来;3、“&”也就是and符号,用于接连两个转义自身;4、escape,用于指定一个非特殊符号为转义符。
本教程操作环境:windows10系统、oracle 11g版、dell g3电脑。
oracle的转义字符是什么1、oracle 特殊字符 转义
关键词:oracle 转义
环境:oracle9i plsql
在plsql里边执行:
update userinfo set pageurl='myjsp?page=1&pagesize=10' where id='test'
这条sql语句往数据库的pageurl字段放进去了一个url地址,但是执行的时候却并非那么理想,因为这其中有一个oracle的特殊字符,需要进行转义,那就是字符'&'.
怎么处理上例中的特殊字符?
两个办法:
1) update userinfo setpageurl='myjsp?page=1'||'&'||'pagesize=10' where id='test'
2) update userinfo setpageurl='myjsp?page=1'||chr(38)||'pagesize=10' where id='test'
其中||是连字符, chr(38)跟ascii的字符转码是一致的。
plsql中还可以set define off来关闭特殊字符,还可以用show define来查看有些特殊定义的字符。
2、oracle 中如何转义 特殊字符
问: 如何转义 下划线 _
select * from ng_values where name like 'lady_%'
jieguo 结果显示 lady_test,lady_test,lady1
正确结果应该是:lady_test,lady_test
不包括lady1
请各位给出转义方法,3ks
answer:
select ... from ... where ... like '/_%' escape '/';
3、
insert into t(col) values(chr(ascii('&'))) ;
(方法一)
例:插入特殊字元'&'
sql> show definedefine "&" (hex 26) ? <--- define的default值是 ‘&’sql> set define offsql> show definedefine offsql> insert into <table_name> values ('at&t');
/
1 row created
(方法二)
sql> show escapeescape off <--- escape的default值是 offsql> set escape onsql> show escapeescape "\" (hex 5c)sql> insert into temp_table values ('select * from emp where ename =\&1');
1 row created.
;
几个测试方法:
select 'myjsp?page=1&pagesize=10' from dual;select 'myjsp?page=1&pagesize=10' from dual;sql> create table a (b varchar2(10)); table created sql> insert into a values('_a');
1 row inserted
sql> select b from a where instr(b,'_a')>0; b ---------- _a select b from a where b like '%\_a%' escape '\'
先启动转义符
set escape on
select b from a where b like '%\_a%' escape '\';select b from a where b like '%\_a%' escape '\';
注意
在oracle中双引号”不是转义字符,因此存储直接存储就可以了,不需要转义了。
oracle转义符有:
1,单引号
在oracle中单引号有两个作用:1)引用字符串;2)对自身转义。
引用字符串时,单引号是成对出现的;而对自身的转义,也必定是双数的,所以,一个sql语句中,单引号必定是成对的.
select 'abc' a,'' b, '''' c, ' '' ' d from dual;
复杂转义字符串可用连接符||拆分,便于理解。连接符号‘||’左右的单引号没有任何的关系,除非‘||’是作为字符串的一部分(这在动态sql中很常见)。
select 'name' || '''''' a, 'name''''' b from dual;output:name''name''
2,双引号
1)一般来说,字符串中的双引号仅仅被当作一个普通字符进行处理。
此时,双引号不需要成对出现:
select 'hh24"小时""mi""分"""ss"秒"' results from dual;output:hh24"小时""mi""分"""ss"秒"
2)当出现在to_char的格式字符串中时,双引号有特殊的作用,就是将非法的格式符包装起来,避免出现ora-01821: date format not recognized错误。
也就是说,去掉双引号和其包含的字符后,剩下的应该是一个合法的格式串。
to_char在处理格式字符串时,会忽略双引号:
select to_char(sysdate, 'hh24"小时"mi"分"ss"秒"') as "当前时间/时分秒" from dual;
output:09小时05分08秒 --别名中也有此应用
格式串为'hh24"小时"mi"分"ss"秒"';
去掉双引号部分后,剩下的是'hh24miss',是一个合法的格式串。
不过即使真不知道双引号的这个用法,也可以这样来处理,虽然麻烦一点:
select to_char(sysdate, 'hh24') || '小时' || to_char(sysdate, 'mi') || '分' || to_char(sysdate, 'ss') || '秒' as result from dual;
output:09小时05分08秒
3,&(and符号)
用来识别/设置自定义变量,后需跟变量名;如需作为字符使用,需使用chr(38),或者接连两个&&(转义自身)
select chr(38) a, 'tom&&jerry' b, 'gun ''n roses' c from dual;output:& tom&jerry gun 'n roses
4, escape(指定转义符)
指定一个非特殊符号为转义符,多用在通配符转义
select table_name from user_tables where table_name like 'tb=_%=_%' escape '=';output:tb_student_score--筛选以tb开头,中间有两个_的表名
推荐教程:《oracle视频教程》
以上就是oracle的转义字符是什么的详细内容。