溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

oracle中怎么轉(zhuǎn)義特殊字符

發(fā)布時間:2021-08-04 15:06:13 來源:億速云 閱讀:193 作者:Leah 欄目:數(shù)據(jù)庫

本篇文章為大家展示了oracle中怎么轉(zhuǎn)義特殊字符,內(nèi)容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。

關(guān)鍵詞: oracle    轉(zhuǎn)義                                          

環(huán)境:oracle 9i  plsql

在plsql里邊執(zhí)行:
update userinfo set pageurl='myjsp?page=1&pagesize=10' where id='test'
這條sql語句往數(shù)據(jù)庫的pageurl字段放進去了一個url地址,但是執(zhí)行的時候卻并非那么理想,因為這其中有一個oracle的特殊字符,需要進行轉(zhuǎn)義,那就是字符'&'.

怎么處理上例中的特殊字符?
兩個辦法:
       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的字符轉(zhuǎn)碼是一致的。
plsql中還可以set define off來關(guān)閉特殊字符,還可以用showdefine來查看有些特殊定義的字符。

2、oracle 中如何轉(zhuǎn)義 特殊字符
問 : 如何轉(zhuǎn)義 下劃線 _

select * from ng_values wherename like 'lady_%'

jieguo 結(jié)果顯示lady_test,lady_test,lady1

正確結(jié)果應(yīng)該是:lady_test,lady_test

不包括 lady1

請各位給出轉(zhuǎn)義方法,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   '\'

先啟動轉(zhuǎn)義符  
  set   escape   on  
  select   B   from   A   where   b   like  '%\_a%'   escape   '\';

select   B   from  A   where   b   like   '%\_a%'   escape  '\'  

上述內(nèi)容就是oracle中怎么轉(zhuǎn)義特殊字符,你們學(xué)到知識或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識儲備,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI