<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

    搜索

    •  

    積分與排名

    • 積分 - 828845
    • 排名 - 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
    主站蜘蛛池模板: 亚洲一区中文字幕久久| 国产亚洲精品bv在线观看| 久热中文字幕在线精品免费| 亚洲国产乱码最新视频| 国产精品免费一区二区三区四区| 亚洲偷自拍拍综合网| 最近中文字幕完整免费视频ww | 精品四虎免费观看国产高清午夜| 亚洲国产成a人v在线| 国产成人精品久久亚洲高清不卡 | 国产精品亚洲一区二区无码| 日本人护士免费xxxx视频| a级毛片免费在线观看| 亚洲日韩国产欧美一区二区三区| 成人免费毛片内射美女APP| 99久久婷婷国产综合亚洲| 和日本免费不卡在线v| 久久久受www免费人成| 国产亚洲中文日本不卡二区| 亚洲中文字幕无码爆乳AV| 午夜网站免费版在线观看| 色偷偷亚洲第一综合| 亚洲精品美女久久久久| 狠狠亚洲婷婷综合色香五月排名| 免费看国产成年无码AV片| 日韩成人免费视频| 无码免费又爽又高潮喷水的视频| 亚洲一区二区久久| 久久精品亚洲综合专区| 91精品免费国产高清在线| 亚洲精品无码成人| 亚洲精品国产情侣av在线| 亚洲精品无码精品mV在线观看| 日本一道高清不卡免费| 亚欧免费视频一区二区三区| 99在线视频免费观看| 人人公开免费超级碰碰碰视频| 国产亚洲一区二区三区在线| 波多野结衣在线免费观看| 日韩电影免费观看| 97无码人妻福利免费公开在线视频|