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

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

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

    隨筆-314  評論-209  文章-0  trackbacks-0

    一、特殊符號ascii定義
     制表符 chr(9)
     換行符 chr(10)
     回車符 chr(13)

    二、嵌套使用repalce,注意每次只能提交一個符號,如先回車再換行
              select REPLACE(gg, chr(10), '') from dual
        要注意chr(13) | | chr(10) 此類結合使用的情況比較多,回車換行在notepad中是比較好看點的,所以要考慮此種情況
              select translate(string,chr(13)||chr(10),',') from dual;
    1、例子一
    create table TEST_1
    (
      VA  VARCHAR2(10),
      VB  NUMBER(2),
      VC  VARCHAR2(10),
      VD  NUMBER(11,2),
      VE  NUMBER(11,4),
      VCL CLOB
    );

    SQL> select vb,vc,replace(vc,chr(10),'') as TT, translate(vc,chr(10),',') from test_1;
     
     VB VC         TT         TRANSLATE(VC,CHR(10),',')
    --- ---------- ---------- -------------------------
      0 Aaaaaaaaa  Aaaaaaaaa  Aaaaaaaaa
      1 Aaaaaaaaa  Aaaaaaaaa  Aaaaaaaaa
      2 大Ba       大Babc帶   大Ba,b,c帶
        b                    
        c帶                  
     
      3 C          C          C
      1 D          D          D
      5 A          A          A
      5 A          A          A
      0 A          A          A
      0 A          A          A
     
     2、例子二
    要注意chr(13) | | chr(10) 此類結合使用的情況比較多,回車換行在notepad中是比較好看點的,所以要考慮此種情況
    select vb,vc,replace(vc,chr(10),'') as TT, translate(vc,chr(13)||chr(10),',') from test_1;
    SQL> select vb,vc,replace(vc,chr(10),'') as TT, translate(vc,chr(13)||chr(10),',') from test_1;
     
     VB VC         TT         TRANSLATE(VC,CHR(13)||CHR(10),
    --- ---------- ---------- ------------------------------
      0 Aaaaaaaaa  Aaaaaaaaa  Aaaaaaaaa
      1 Aaaaaaaaa  Aaaaaaaaa  Aaaaaaaaa
      2 大Ba       大Babc帶   大Babc帶
        b                    
        c帶                  
     
      3 C          C          C
      1 D          D          D
      5 A          A          A
      5 A          A          A
      0 A          A          A
      0 A          A          A
     
    11 rows selected

    三、對于字符大對象的符號處理
        對于clob字段中的符號處理,先to_char然后一樣的處理

    SQL> select to_char(vcl),replace(to_char(vcl),chr(10),'[]') from test_1;
     
    TO_CHAR(VCL)                                                                     REPLACE(TO_CHAR(VCL),CHR(10),'
    -------------------------------------------------------------------------------- --------------------------------------------------------------------------------
    嵌套使用repalce,注意每次只能提交一個符號,如先回車再換行                        嵌套使用repalce,注意每次只能提交一個符號,如先回車再換行[]select REPLACE(gg, chr(10), '') from dual[]sel
    select REPLACE(gg, chr(10), '') from dual                                       
    select translate(string,chr(13)||chr(10),',') from dual;    

    func:

     

    2.2.1      單記錄字符函數

            函     數                      說                明
      ASCII                     返回對應字符的十進制值
      CHR                       給出十進制返回字符 
     CONCAT                    拼接兩個字符串,與  ||       相同
      INITCAT                   將字符串的第一個字母變為大寫
      INSTR                     找出某個字符串的位置
      INSTRB                    找出某個字符串的位置和字節數
      LENGTH                    以字符給出字符串的長度
      LENGTHB                   以字節給出字符串的長度
      LOWER                     將字符串轉換成小寫
      LPAD                      使用指定的字符在字符的左邊填充
      LTRIM                     在左邊裁剪掉指定的字符
      RPAD                      使用指定的字符在字符的右邊填充
      RTRIM                     在右邊裁剪掉指定的字符
      REPLACE                   執行字符串搜索和替換
      SUBSTR                    取字符串的子串
      SUBSTRB                   取字符串的子串(以字節)
      SOUNDEX                   返回一個同音字符串
      TRANSLATE                 執行字符串搜索和替換
      TRIM                      裁剪掉前面或后面的字符串
      UPPER                     將字符串變為大寫
      NVL                       以一個值來替換空值

    ASCII(<c1>)
    <c1>是字符串。返回與指定的字符對應的十進制數。
    SQL> select ascii('A') A,ascii('a') a,ascii('0') zero,ascii(' ') space from dual;

         A      a  ZERO   SPACE
    ---------- ---------- ---------- ----------
         65     97     48     32

    SQL> select ascii('趙') zhao,length('趙') leng from dual;

          ZHAO        LENG
        ----------  ----------
         54740         1

    CHR(<I>[NCHAR])
    給出整數,返回對應字符。如:

    SQL> select chr(54740) zhao,chr(65) chr65 from dual;

    ZH   C
    --  -
    趙  A

    CONCAT(<c1>,<c2>)
    SQL> select concat('010-','8801 8159')||'轉23' 趙元杰電話  from dual;

    趙元杰電話

    -----------------

    010-8801 8159 轉23

    INITCAP(<c1>)

    返回字符串c1       并第一個字母變為大寫。例如:

    SQL> select initcap('simth') upp from dual;

    UPP
    -----
    Simth

    INSTR(<c1>,<c2>[,<I>[,<j>] ] )
    在一個字符串中搜索指定的字符,返回發現指定的字符的位置。
    C1: 被搜索的字符串 
    C2: 希望搜索的字符串 
    I: 搜索的開始位置,缺省是1 
    J: 出現的位置,缺省是1。 

    SQL> SELECT INSTR ('Oracle Training', 'ra', 1, 2) "Instring" FROM DUAL;

      Instring

    ----------

            9

    INSTRB(<c1>,<c2>[,<I>[,<j>] ] )

    除了返回的字節外 ,與INSTR              相同,

    LENGTH( <c> )

    返回字符串  c      的長度。

    SQL> l
     1  select name,length(name),addr,length(addr),sal,length(to_char(sal))
      2* from nchar_tst
    SQL> /

    NAME    LENGTH(NAME) ADDR            LENGTH(ADDR) SAL LENGTH(TO_CHAR(SAL))

    ------   ------------  ----------------  ------------  ----------  ----------------

    趙元杰          3        北京市海淀區                 6         99999.99    8

    LENGTHB( <c> )

    以字節返回字符串的字節數。

    SQL> select name,lengthb(name),length(name) from nchar_tst;

    NAME     LENGTHB(NAME)       LENGTH(NAME)

    ------   -------------   ------------

    趙元杰                 6             3

    LOWER ( <c> )
    返回字符串并將所有字符變為小寫。

    SQL> select lower('AaBbCcDd') AaBbCcDd from dual;

    AABBCCDD

    --------

    aabbccdd

    UPPER( <c>)
    與  LOWER    相反,將給出字符串變為大寫。如:

    SQL>    select upper('AaBbCcDd') AaBbCcDd from dual;

    AABBCCDD

    --------

    AABBCCDD
    RPAD 和LPAD(粘貼字符)
     
    RPAD(string,Length[,'set']) 
    LPAD(string,Length[,'set']) 
          RPAD在列的右邊粘貼字符; 
          LPAD在列的左邊粘貼字符。 
     
    例 1: 
    SQL>select   RPAD(City,35,'.'),temperature    from  weather; 
     
            RPAD(City,35,'.')            temperature 
            -------------------------- ---------------- 
               CLEVELAND......                    85 
               LOS  ANGELES..                     81 
              ......................... 
     
            (即不夠 35 個字符用'.'填滿) 

    LTRIM(左截斷)RTRIM(右截斷) 函數 
     

    LTRIM (string [,’set’])

    Left TRIM (左截斷)刪去左邊出現的任何set 字符。 

    RTRIM (string [,’set’])

    Right TRIM (右截斷)刪去右邊出現的任何set 字符。 

    例1: 

    SELECT RTRIM (‘Mother Theresa, The’, ‘The’) “Example of Right

    Trimming” FROM DUAL;

    Example of Right

    ----------------

    Mother Theresa,

    SUBSTR Substr(string,start[,Count])

    取子字符串中函數 
    對字串 (或字段),從 start字符 開始,連續取 count 個字符并返回結果,如果沒有指 count
    則一直取到尾。 
     
    select phone,substr(phone,1,3) || ‘0’ || substr(phone,4) 
    from telecommunication where master ’中國電信’; 
     

    SUBSTRB(string,start[,Count])
    對字串 (或字段),從 start字節 開始,連續取 count 個字節并返回結果,如果沒有指 count
    則一直取到尾。 
     
     
    REPLACE (‘string’ [,’string_in’,’string_out’])

    String: 希望被替換的字符串或變量。 
    String_in: 被替換字符串。 
    String_out: 要替換字符串。 
     
    SQL> select replace('Informaix 中國公司','Informaix','IBM Informix')
      2  IBM 數據庫  from dual;

    IBM 數據庫
    --------------------
    IBM Informix 中國公司

    SOUNDEX( <c> )

    返回一個與給定的字符串讀音相同的字符串(不管拼寫是否一樣)。

    SELECT DPL_NAME FROM DENIED_PARTIES_LIST WHERE
    SOUNDEX(DPL_NAME) = SOUNDEX(‘Saddam Hussain’) ;
    DPL_NAME
    ----------------------------------------------
    Al Husseni
    Sadda Al Sada.

    REPLACE (‘string’ [,’string_in’,’string_out’])

    String:希望被替換的字符串或變量。 
    String_in: 被替換字符串。 
    String_out: 要替換字符串。 
     
    SELECT REPLACE (‘Oracle’, ‘Or’, ‘Mir’) “Example “ FROM DUAL; 
    Example 
    ------- 
    Miracle 

    TRIM  ( [<leading>] <trailing> FROM <trim_char>     )
    RIM可以使你對給定的字符串進行裁剪(前面,后面或前后)。 

    z 如果指定 LEADING, Oracle 從trim_char 中裁剪掉前面的字符; 
    z 如果指定TRAILING, Oracle 從trim_char 中裁剪掉尾面的字符; 
    z 如果指定兩個都指定或一個都沒有給出,Oracle從trim_char 中裁剪掉前面及尾面的字
       符; 
    z 如果不指定 trim_character, 缺省為空格符; 
    z 如果只指定trim_source, Oracle Oracle從trim_char 中裁剪掉前面及尾面的字符。 
     
    例子:將下面字符串中的前面和后面的‘0                   ‘字符都去掉:

    SELECT TRIM (0 FROM 0009872348900) "TRIM Example" FROM DUAL;

    TRIM example

    --------------------------------

    98723489

     

    語法:TRANSLATE(expr,from,to)

    om,to) expr: 代表一串字符,

    expr: 代表一串字符,from 與 to 是從左到右一一對應的關系,如果不能對應,則視為空值。

    舉例:

    select translate('abcbbaadef','ba','#@') from dual (b將被#替代,a將被@替代)

    select translate(ab

    select translate('abcbbaadef','bad','#@') from dual (b將被#替代,a將被@替代,d對應的值是空值,將被移走)

    因此:結果依次為:@#c##@@def 和@#c##@@ef

    posted on 2010-04-22 11:10 xzc 閱讀(10674) 評論(0)  編輯  收藏 所屬分類: Oracle
    主站蜘蛛池模板: 亚洲AV午夜成人影院老师机影院| 国产精品xxxx国产喷水亚洲国产精品无码久久一区 | 亚洲国产成人手机在线观看| 免费毛片a在线观看67194 | 免费看男女下面日出水视频 | 国产在线国偷精品免费看| 又大又硬又爽免费视频| 免费在线观看一区| 亚洲日韩国产成网在线观看| 国产精品九九久久免费视频| 亚洲熟妇无码AV在线播放| 在线观看人成视频免费无遮挡| 亚洲AV中文无码字幕色三| 三年片在线观看免费观看大全动漫| 亚洲综合一区二区精品导航| 精品香蕉在线观看免费| 中文字幕亚洲无线码| 亚洲免费精彩视频在线观看| 国产AV无码专区亚洲Av| a级毛片毛片免费观看久潮喷 | 国产一卡二卡3卡四卡免费| 亚洲一区二区三区亚瑟 | 亚洲综合色在线观看亚洲| 久久最新免费视频| 亚洲精品视频免费看| 日韩视频在线免费| 一级毛片不卡免费看老司机| 亚洲日韩乱码中文无码蜜桃臀网站| 久久免费视频精品| 亚洲人成色777777老人头| 亚洲一区无码精品色| 永久免费视频网站在线观看| 亚洲国产成人精品无码区花野真一| 国产亚洲精品精品国产亚洲综合| 97国产在线公开免费观看| 无码亚洲成a人在线观看| 亚洲Av无码精品色午夜| 全免费一级毛片在线播放| 99精品全国免费观看视频..| 中文字幕亚洲男人的天堂网络| 2048亚洲精品国产|