<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年7月>
    293012345
    6789101112
    13141516171819
    20212223242526
    272829303112
    3456789

    常用鏈接

    留言簿(14)

    隨筆檔案(6)

    文章分類(467)

    文章檔案(423)

    相冊

    收藏夾(18)

    JAVA

    搜索

    •  

    積分與排名

    • 積分 - 828831
    • 排名 - 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 閱讀(535) 評論(0)  編輯  收藏 所屬分類: oracle
    主站蜘蛛池模板: 插B内射18免费视频| 日韩免费的视频在线观看香蕉| 成人免费大片免费观看网站| 精品亚洲AV无码一区二区| 亚洲视频在线免费观看| 婷婷亚洲综合五月天小说| 亚洲国产成人精品无码区在线秒播| 久久久久久久久久国产精品免费 | 久久精品亚洲日本佐佐木明希| 国产精品免费久久久久电影网| 久久精品亚洲乱码伦伦中文| 中文字幕免费播放| 伊人久久大香线蕉亚洲| 久久青草免费91观看| 亚洲第一页中文字幕| 在线观看特色大片免费视频| 国产AV旡码专区亚洲AV苍井空| 毛片免费视频在线观看| 亚洲av中文无码乱人伦在线观看| 日韩精品视频免费在线观看| 亚洲AV无码AV男人的天堂不卡 | 91在线免费观看| 亚洲精品福利视频| 一级女人18毛片免费| 亚洲av成人无码网站…| 亚洲精品视频久久久| 免费精品一区二区三区第35| 亚洲精品综合久久中文字幕| 成人免费视频软件网站| 免费国产va视频永久在线观看| 亚洲日韩欧洲无码av夜夜摸| 在线美女免费观看网站h| 亚洲精品宾馆在线精品酒店| 亚洲电影日韩精品| 久久国产精品免费视频| 亚洲国产乱码最新视频| 亚洲视频一区二区| 91成人免费在线视频| 人人爽人人爽人人片av免费| 少妇中文字幕乱码亚洲影视| 日韩一品在线播放视频一品免费|