孤燈野火
          暢想的天空
          posts - 2,comments - 4,trackbacks - 0
          1、oracle 特殊字符 轉義
          關鍵詞: oracle    轉義                                          
          環境:oracle 9i  plsql
          在plsql里邊執行:
          update userinfo set pageurl='myjsp?page=1&pagesize=10' where id='test'
          這條sql語句往數據庫的pageurl字段放進去了一個url地址,但是執行的時候卻并非那么理想,因為這其中有一個oracle的特殊字符,需要進行轉義,那就是字符'&'.
          怎么處理上例中的特殊字符?
          兩個辦法:
                 1) update userinfo set pageurl='myjsp?page=1'||'&'||'pagesize=10' where id='test'
                  2) update userinfo set pageurl='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   '\'
          posted on 2011-10-26 22:18 孤飛燕 閱讀(21372) 評論(0)  編輯  收藏 所屬分類: 數據庫
          主站蜘蛛池模板: 浪卡子县| 苏尼特左旗| 余干县| 绍兴县| 衡山县| 平原县| 娱乐| 惠安县| 东莞市| 岫岩| 山西省| 慈溪市| 胶南市| 新泰市| 芦山县| 清镇市| 宜章县| 开平市| 防城港市| 鄯善县| 宝鸡市| 四会市| 铁岭市| 正定县| 荥经县| 怀集县| 手机| 清丰县| 佳木斯市| 新竹县| 合山市| 黔西| 江都市| 三穗县| 杭锦后旗| 淮阳县| 麻江县| 堆龙德庆县| 霍山县| 丰顺县| 封丘县|