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

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

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

    氧氣中毒 - J2EE

    爪吐奕奕征途
    posts - 24, comments - 10, trackbacks - 0, articles - 0
       :: 首頁 :: 新隨筆 ::  ::  :: 管理

    使用Java編寫oracle存儲過程

    Posted on 2006-06-14 15:00 氧氣中毒 閱讀(1001) 評論(0)  編輯  收藏 所屬分類: 數據處理
    通常我們都使用pl/sql為oracle編寫存儲過程,從oracle?8開始我們可以有另一種選擇:Java。8.0開始,oracle自帶一個jvm,內置對java的支持,任何java能做的事情你都可以放到oracle里面來做,你甚至可以在里面操作db2。這讓oracle具備了極其巨大的擴展能力,只要你愿意,完全可以開發一個trigger,讓它在適當的時候給管理員的msn發送一條即時消息。

    ????好消息說完了,現在是壞消息:由于pl/sql是過程化的語言,它基本上不具備多態的概念,供oracle使用的java方法必須申明為static,所以在oracle中你無法使用java的動態特性,比如接口、反射等。不過這并不妨礙你用java做愛做的事。

    ????我們以一個簡單的hello?world為例,我想任何一個有經驗的java程序員都能夠通過這個例子,派生出其他希奇古怪的應用,有好的創意記得要與我共享,我的msn是chenzhihuang@yahoo.com.cn

    ????首先是創建一個java類,你可以用jbuilder/eclipse來編寫,也可以直接在oracle的控制臺里面創建。前者不多說,看看后一種方式。

    ????啟動sql?plus,執行如下命令:

    1. create?or?replace?and?compile?java?source?named?"hello_sp"?as
    2. /**
    3. ?*創建oracle存儲過程的java類
    4. ?*@author?zhchen
    5. **/
    6. package?org.bromon.oracle;
    7. public?class?Hello
    8. {
    9. ??public?static?String?say(String?name)
    10. ??{
    11. ????return?"你好,"+name;
    12. ??}
    13. }

    Java以創建。

    然后在oracle中把這個類導入成為一個函數,執行命令:
    1. create?or?replace?function?hello_sp(name?varchar2)?return?varchar2
    2. as?language?java?name?
    3. 'org.bromon.oracle.Hello.say(java.lang.String)?return?java.lang.String';


    函數已創建

    現在可以調用該函數,執行:
    1. select?hello('zhchen')?from?dual;


    返回結果:你好,zhchen

    有一個需要注意的問題是,假如我們的java方法是沒有參數的,比如:
    1. public?static?String?say()
    2. ??{
    3. ????return?"你好”;
    4. ??}

    那么在創建函數的時候,函數名不應該有擴號:hello_sp
    否則會報告函數有編譯錯誤。

    如果你的java類是在IDE里面編寫的,那么只需要在oracle中加載編譯過的class文件即可,方法是:

    啟動enterprise?manage?console,在“方案”下找到“源類型”,右擊”java類”,選擇”加載java“,選擇對應的class文件即可。
    主站蜘蛛池模板: 自拍偷自拍亚洲精品偷一| 亚洲国产成人精品电影| 精品特级一级毛片免费观看| 成人a免费α片在线视频网站| 亚洲精品视频在线观看免费| **一级毛片免费完整视| 亚洲精品乱码久久久久久下载| 免费无码中文字幕A级毛片| 亚洲天堂福利视频| 国产成人A在线观看视频免费| 亚洲午夜无码毛片av久久京东热 | 免费观看在线禁片| 亚洲无线电影官网| 免费毛片a在线观看67194| 国产亚洲免费的视频看| 亚洲AV中文无码乱人伦下载| 亚洲高清免费在线观看| 2017亚洲男人天堂一| 免费v片在线观看品善网| 精品国产免费一区二区三区| 亚洲avav天堂av在线不卡| 91嫩草免费国产永久入口| 亚洲乱亚洲乱妇无码| 亚洲日韩人妻第一页| 玖玖在线免费视频| 亚洲1234区乱码| 免费人妻无码不卡中文字幕18禁| 国产精品1024在线永久免费| 久久精品国产亚洲AV电影| 久久电影网午夜鲁丝片免费| 无码日韩人妻AV一区免费l| 亚洲AV成人片色在线观看高潮| 免费观看激色视频网站bd| 精品亚洲成a人在线观看| 久久综合九九亚洲一区| 成年午夜视频免费观看视频| 一级毛片免费在线观看网站| 亚洲国产精品不卡在线电影| 日韩免费高清视频网站| 午夜免费福利小电影| 午夜亚洲乱码伦小说区69堂|