今天进行一个查询时发现查询的结果不太对:
SQL> select text from user_source where text like '%_32_%';
SQL> select text from user_source where text like '%_32_%';
TEXT
--------------------------------------------------------------------------------
||' partition p32 values less than ('||'''120410'''||'),'
-- Created : 2012/7/20 14:55:32
p_uclog_aft('FM_32_bsp',i_sequnum_uc);
ELSE o_vc_message:='SUCCESS IN MIGRATE FM_32_bsp'|
--------------------------------------------------------------------------------
||' partition p32 values less than ('||'''120410'''||'),'
-- Created : 2012/7/20 14:55:32
p_uclog_aft('FM_32_bsp',i_sequnum_uc);
ELSE o_vc_message:='SUCCESS IN MIGRATE FM_32_bsp'|
4 rows selected
我想要的是含有"_32_"四个字符的,而得到的却是按"32"查询出来的结果。
这个时候就需要使用转移字符,即escape格式:
SQL> select text from user_source where text like '%__32__%' escape '_';
TEXT
--------------------------------------------------------------------------------
p_uclog_aft('FM_32_bsp',i_sequnum_uc);
ELSE o_vc_message:='SUCCESS IN MIGRATE FM_32_bsp'|
--------------------------------------------------------------------------------
p_uclog_aft('FM_32_bsp',i_sequnum_uc);
ELSE o_vc_message:='SUCCESS IN MIGRATE FM_32_bsp'|
2 rows selected
查看了oracle的reference,我们平时只注意到了%代表任意字符,其实还有一个通配符被我们忽略了。
_代表一个字符。
比如我在添加一个存储过程:
create or replace procedure P_D is
c32 varchar2(10);
c32 varchar2(10);
bx32 varchar2(10):=
132;
begin
if bx32
=32 then
dbms_output.put_line('~a~');
end if;
end ;
create or replace procedure P_D is
c32 varchar2(10);
c32 varchar2(10);
bx32 varchar2(10):=
132;
begin
if bx32
=32 then
dbms_output.put_line('~a~');
end if;
end ;
执行 select * from user_source where text like '_32%'
结果为:
NAME TYPE LINE TEXT
1 P_D PROCEDURE 2 "c32 varchar2(10);
"
2 P_D PROCEDURE 5 "132;
"
3 P_D PROCEDURE 8 "=32 then
"
也就是说,在匹配一个字符时,空格也是计算在内的。'_'匹配了一个数字、字母或符号(只要是一个字符)
结果为:
NAME TYPE LINE TEXT
1 P_D PROCEDURE 2 "c32 varchar2(10);
"
2 P_D PROCEDURE 5 "132;
"
3 P_D PROCEDURE 8 "=32 then
"
也就是说,在匹配一个字符时,空格也是计算在内的。'_'匹配了一个数字、字母或符号(只要是一个字符)
escape的作用其实就是转义通配符。在like中,通配符只有%和_。其他符号都可以直接调用。
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/26451536/viewspace-761050/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/26451536/viewspace-761050/