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

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

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

    隨筆 - 6  文章 - 129  trackbacks - 0
    <2025年5月>
    27282930123
    45678910
    11121314151617
    18192021222324
    25262728293031
    1234567

    常用鏈接

    留言簿(14)

    隨筆檔案(6)

    文章分類(467)

    文章檔案(423)

    相冊

    收藏夾(18)

    JAVA

    搜索

    •  

    積分與排名

    • 積分 - 825594
    • 排名 - 49

    最新評論

    閱讀排行榜

    評論排行榜

    轉:http://www.eygle.com/faq/Faq_convert.htm
    1.16進制轉換為10進制

    可以通過to_number函數實現 

    SQL> select to_number('19f','xxx') from dual;

    TO_NUMBER('19F','XXX')
    ----------------------
    415

    SQL> select to_number('f','xx') from dual;

    TO_NUMBER('F','XX')
    -------------------
    15

    2.10進制轉換為16進制
    可以通過to_char函數轉換

    SQL> select to_char(123,'xxx') from dual;

    TO_C
    ----
    7b

    SQL> select to_char(4567,'xxxx') from dual;

    TO_CH
    -----
    11d7

    3.2進制轉換為10進制

    從Oracle9i開始,提供函數bin_to_num進行2進制到10進制的轉換

    SQL> select bin_to_num(1,1,0,1) a,bin_to_num(1,0) b from dual;

    A B
    ----- ----------
    13 2

    SQL> select bin_to_num(1,1,1,0,1) from dual;

    BIN_TO_NUM(1,1,1,0,1)
    ---------------------
    29

    3.進制轉換也可以通過自定義函數實現
    以下函數來自AskTom網站,是Tom給出的例子,供參考:

    create or replace function to_base( p_dec in number, p_base in number )
    return varchar2
    is
    l_str varchar2(255) default NULL;
    l_num number default p_dec;
    l_hex varchar2(16) default '0123456789ABCDEF';
    begin
    if ( trunc(p_dec) <> p_dec OR p_dec < 0 ) then
    raise PROGRAM_ERROR;
    end if;
    loop
    l_str := substr( l_hex, mod(l_num,p_base)+1, 1 ) || l_str;
    l_num := trunc( l_num/p_base );
    exit when ( l_num = 0 );
    end loop;
    return l_str;
    end to_base;
    /


    create or replace function to_dec
    ( p_str in varchar2,
    p_from_base in number default 16 ) return number
    is
    l_num number default 0;
    l_hex varchar2(16) default '0123456789ABCDEF';
    begin
    for i in 1 .. length(p_str) loop
    l_num := l_num * p_from_base + instr(l_hex,upper(substr(p_str,i,1)))-1;
    end loop;
    return l_num;
    end to_dec;
    /
    show errors

    create or replace function to_hex( p_dec in number ) return varchar2
    is
    begin
    return to_base( p_dec, 16 );
    end to_hex;
    /
    create or replace function to_bin( p_dec in number ) return varchar2
    is
    begin
    return to_base( p_dec, 2 );
    end to_bin;
    /
    create or replace function to_oct( p_dec in number ) return varchar2
    is
    begin
    return to_base( p_dec, 8 );
    end to_oct;
    /

    -The End-





    posted on 2010-05-18 09:44 Ke 閱讀(529) 評論(0)  編輯  收藏 所屬分類: oracle
    主站蜘蛛池模板: 成人毛片18岁女人毛片免费看| 日本在线观看免费高清| 国产婷婷成人久久Av免费高清| 国产成人精品高清免费| 亚洲色大成网站www久久九| 午夜性色一区二区三区免费不卡视频 | 亚洲国产精品专区在线观看| 国产精品亚洲精品日韩动图| 亚洲第一黄色网址| 国产特黄一级一片免费| 亚洲国产精品一区二区成人片国内| 在线观看免费黄色网址| 无码久久精品国产亚洲Av影片| 日本一卡精品视频免费| 亚洲男人的天堂在线| 久久WWW色情成人免费观看| 亚洲精品无码av中文字幕| 免费在线观看亚洲| 久久精品无码免费不卡| 亚洲AV日韩AV永久无码绿巨人 | 无码天堂va亚洲va在线va| 免费国产人做人视频在线观看| 一区二区三区免费在线视频| 亚洲日韩v无码中文字幕 | 国产成人高清精品免费观看| 亚洲va无码手机在线电影| jjizz全部免费看片| 亚洲av片在线观看| 亚洲最大AV网站在线观看| 毛片无码免费无码播放| 亚洲午夜精品久久久久久app| 免费a级毛片永久免费| 18禁超污无遮挡无码免费网站| 亚洲一区二区三区在线| 又大又硬又爽免费视频| 亚洲国产精品免费视频| 亚洲AV无码之国产精品| 亚洲av日韩av不卡在线观看 | fc2免费人成在线视频| 亚洲视屏在线观看| 国产国产人免费人成免费视频|