欢迎来到天天文库
浏览记录
ID:34724972
大小:53.16 KB
页数:10页
时间:2019-03-10
《oracle中escape关键字用法》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库。
1、ORACLE中ESCAPE关键字用法2012-09-1900:00比特网悠虎关键字: 定义:escape关键字经常用于使某些特殊字符,如通配符:'%','_'转义为它们原来的字符的意义,被定义的转义字符通常使用'',但是也可以使用其他的符号。 实例: SQL>select*fromt11wherenamelike'%_%'; NAME --------- aa_a aaa SQL>select*fromt11wherenamelike'%_%'escape''; NAME --
2、-------- aa_a 注意:如果是'/'作为检索字符,必须用'/'作为转义符,正斜扛也一样。 select*fromwan_testwherepsidlike'%//%'escape'/' 1.使用ESCAPE关键字定义转义符。在模式中,当转义符置于通配符之前时,该通配符就解释为普通字符。 2.ESCAPE'escape_character'允许在字符串中搜索通配符而不是将其作为通配符使用。escape_character是放在通配符前表示此特殊用途的字符。 select*fromaW
3、HEREnameLIKE'%/%ab'ESCAPE'/' 结果为: name ---------- 11%ab 12%ab ================================================================================== SQL>select*fromtest; TEST -------------------- sdd_kk d'd dfsfsa dffa%asfs 12345 1%2345 1%543
4、21 2%54321 %%54321 A&B 已选择9行。 其中包含特殊的字符分别为%,_,&,有可能包含这些字符的数据含有错误,或者需要查找包含这些字符的数据。 SQL>select*fromtestwheretestlike'sdd_%'escape''; TEST -------------------- sdd_kk 转义字符为''(空格); SQL>select*fromtestwheretestlike'sdd_%'escape''; TEST --------
5、------------ sdd_kk 转义字符为''; SQL>select*fromtestwheretestlike'sdd=_%'escape'='; TEST -------------------- sdd_kk 转义字符为'='; SQL>select*fromtestwheretestlike'sdd/_%'escape'/'; TEST -------------------- sdd_kk转义字符为'/'; SQL>select*fromtestwheret
6、estlike'sddd_%'escape'd';转义字符和转义字符后面的一个字符的成对的,转义字符本身不参加匹配,如果转义字符后面的一个字符本身没有特殊意义,会提示转义字符无效 未选定行 转义字符为d,没有实现转义功能; SQL>select*fromtestwheretestlike'%_%'escape''; TEST -------------------- sdd_kk 查找包含所有'_'的字段。 同理:通过这种方法查找含有'%'的所有字段: SQL>select*fro
7、mtestwheretestlike'%%%'escape''; TEST -------------------- dffa%asfs 1%2345 1%54321 2%54321 %%54321 但是'&'不能通过转义字符查找: SQL>select*fromtestwheretestlike'%&%'escape''; select*fromtestwheretestlike'%&%'escape'' * 第1行出现错误: ORA-01424:转义符之后字符缺
8、失或非法 可以通过另外的方式进行转义: SQL>selectascii('&')fromdual; ASCII('&') ---------- 38 SQL>select*fromtestwheretestlike'%'
9、
10、chr(38)
11、
12、'%'; TEST -------------------- A&B '''的转义: SQL>select*fromtestwheretestlike'%''%'; TEST
此文档下载收益归作者所有