<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    Decode360's Blog

    業精于勤而荒于嬉 QQ:150355677 MSN:decode360@hotmail.com

      BlogJava :: 首頁 :: 新隨筆 :: 聯系 ::  :: 管理 ::
      397 隨筆 :: 33 文章 :: 29 評論 :: 0 Trackbacks
    Oracle的轉義字符
    ?
    ??? 對于Oracle的轉義字符,對然了解,但是一直不是很明白。而且在SQLPlus下的ESCAPE還和函數ESCAPE不是一個意思,更加容易搞混,所以專門來學習一下。首先可以通過幾個簡單的例子來了解一下這個函數在SQL中的用法。
    ?
    SQL> create table t_char(a varchar2(20));
    SQL> insert into t_char values('a_b');
    SQL> insert into t_char values('acb');
    SQL> insert into t_char values('a%b');
    SQL> insert into t_char values('a''b');
    SQL> insert into t_char values('a/b');
    SQL> insert into t_char values('a\b');
    SQL> insert into t_char values('%');
    SQL> insert into t_char values('_');
    SQL> insert into t_char values('a');
    SQL> commit;
    ?
    SQL> select * from t_char;
    A
    --------------------
    a_b
    acb
    a%b
    a'b
    a/b
    a\b
    %
    _
    a
    ?
    SQL> select * from t_char where a like 'a_b';
    A
    --------------------
    a_b
    acb
    a%b
    a'b
    a/b
    a\b
    ?
    SQL> select * from t_char where a like 'a\_b' escape '\';
    A
    --------------------
    a_b
    ?
    --可見要查詢含有通配字符的字符串,必須要使用escape函數
    ?
    ?
    SQL> select * from t_char where a like 'a\'b' escape '\';
    ERROR:
    ORA-01756: quoted string not properly terminated

    SQL> select * from t_char where a like 'a''b' escape '\';
    A
    --------------------
    a'b
    ?
    --但是字符'還是需要用兩個''來代替字符串中的單引號
    ?
    ?
    SQL> select * from t_char where a like 'ax_b' escape 'x';
    A
    --------------------
    a_b
    ?
    SQL> select * from t_char where a like 'a''_b' escape '''';
    A
    --------------------
    a_b
    ?
    SQL> select * from t_char where a like 'a_%b' escape '_';
    A
    --------------------
    a%b
    ?
    --可以用其他字符,甚至是“'”、“_”、“%”來用作轉義字符,但是一般都使用\,以免發生邏輯錯誤
    ?
    ?
    SQL> select * from t_char where a like 'a\/b' escape '\';
    select * from t_char where a like 'a\/b' escape '\'
    ????????????????????????????????? *
    ERROR at line 1:
    ORA-01424: missing or illegal character following the escape character

    SQL> select * from t_char where a like 'a_/b' escape '_';
    select * from t_char where a like 'a_/b' escape '_'
    ????????????????????????????????? *
    ERROR at line 1:
    ORA-01424: missing or illegal character following the escape character
    ?
    SQL> select * from t_char where a like 'a//b' escape '/';
    A
    --------------------
    a/b
    ?
    SQL> select * from t_char where a like 'a/\b' escape '/';
    select * from t_char where a like 'a/\b' escape '/'
    ????????????????????????????????? *
    ERROR at line 1:
    ORA-01424: missing or illegal character following the escape character
    ?
    SQL> select * from t_char where a like 'a\\b' escape '\';
    A
    --------------------
    a\b

    ?
    --要搜索"/"或者"\"則必須使用與之相同的符號作為轉義字符,否則無效
    ?
    ?
    --基本上的使用方法就是這些了,最后再強調一下:這里的escape函數,和sqlplus中的escape環境參數·毫·無·關·系·
    ?
    SQL> show escape
    escape OFF

    ?
    posted on 2009-03-27 20:51 decode360 閱讀(1873) 評論(0)  編輯  收藏 所屬分類: 05.SQL
    主站蜘蛛池模板: 无码乱人伦一区二区亚洲| 免费在线观看的黄色网址| 可以免费观看的国产视频| 国产高潮久久免费观看| 一个人免费视频在线观看www| 在线涩涩免费观看国产精品| 中文字幕亚洲一区二区va在线| 人人狠狠综合久久亚洲婷婷| 亚洲日本在线免费观看| 亚洲色最新高清av网站| 一级毛片视频免费观看| 亚洲免费一级视频| 国产精品无码一二区免费 | 亚洲成a人无码亚洲成www牛牛| 永久免费无码日韩视频| 亚洲一区二区三区免费视频| 4480yy私人影院亚洲| 美女免费视频一区二区| 1000部无遮挡拍拍拍免费视频观看| 在线看片无码永久免费aⅴ| 无码久久精品国产亚洲Av影片| 一区二区免费视频| 又黄又爽的视频免费看| 老司机精品免费视频| 久久久久亚洲精品日久生情| 亚洲国产综合专区在线电影| 国产亚洲精品影视在线| 最近中文字幕免费大全| 成人永久免费高清| xxxxx做受大片在线观看免费| 亚洲精品字幕在线观看| 国产偷国产偷亚洲高清在线| 国产成人精品免费午夜app| 亚洲人成电影网站久久| 亚洲国产精品人人做人人爽 | 精品熟女少妇av免费久久| 亚洲人成无码www久久久| 亚洲高清毛片一区二区| 亚洲国产成人精品无码久久久久久综合 | 国产免费爽爽视频在线观看| 国产成人亚洲合集青青草原精品|