【Oracle】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 DEFINE
define "&" (hex 26) ? <--- DEFINE的default值是 ‘&’
SQL> SET DEFINE OFF
SQL> SHOW DEFINE
define OFF
SQL> INSERT INTO <table_name> VALUES ('AT&T');
/
1 row created

(方法二)
SQL> SHOW ESCAPE
escape OFF <--- ESCAPE的default值是 OFF
SQL> SET ESCAPE ON
SQL> SHOW ESCAPE
escape "\" (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中雙引號”不是轉義字符,因此存儲直接存儲就可以了,不需要轉義了。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章