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

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

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

    隨筆-7  評(píng)論-24  文章-102  trackbacks-0

    文章出處:http://www.diybl.com/course/3_program/java/javajs/2008324/106036.html

    hibernate3.0以上提供了兩種方式執(zhí)行存儲(chǔ)過(guò)程。

    第一種 :用JDBC方式(獲得 Connection 對(duì)象)
    Session session =HibernateSessionFactory.getSession(); //獲取hibernate會(huì)話

    Connection conn 
    = session.connection(); // 用session對(duì)象獲取連接

    ResultSet rs 
    =null;

    try
      
    {
        CallableStatement call 
    = conn.prepareCall("{Call pro_getManager(?,?)}");

       call.setString(
    1"admin");
       call.setString(
    2"admin");
       rs 
    = call.executeQuery();

      }

      
    catch (Exception e)
      
    {
       e.printStackTrace();
      }
    finally
      
    {

       rs.close();
    //關(guān)閉
       session.close();//關(guān)閉連接
       HibernateSessionFactory.closeSession(); //關(guān)閉會(huì)話
      }


    這種方式本人感覺(jué)與hibernate結(jié)合不很緊密,還難以控制,還要自己控制關(guān)閉

     
    第二種: 用hibernate中SQLQuery 接口執(zhí)行,其實(shí)與執(zhí)行sql沒(méi)有兩樣。
    Session session =HibernateSessionFactory.getSession(); //獲取hibernate會(huì)話

    String procName
    ="{Call pro_getManager(?,?) }"

    SQLQuery query 
    = session.createSQLQuery(proc);
    query.setString(
    0"admin");
    query.setString(
    1"admin");
    List list 
    =query.list();

    session.close();

    HibernateSessionFactory.closeSession();

    SQLQuery 接口功能很強(qiáng)大吧


    APIConnection 方法:
    CallableStatement prepareCall(String sql) throws SQLException

    創(chuàng)建一個(gè) CallableStatement 對(duì)象來(lái)調(diào)用數(shù)據(jù)庫(kù)存儲(chǔ)過(guò)程。CallableStatement 對(duì)象提供了設(shè)置其 IN 和 OUT 參數(shù)的方法,以及用來(lái)執(zhí)行調(diào)用存儲(chǔ)過(guò)程的方法。

     

    public interface CallableStatement extends PreparedStatement

    用于執(zhí)行 SQL 存儲(chǔ)過(guò)程的接口。JDBC API 提供了一個(gè)存儲(chǔ)過(guò)程 SQL 轉(zhuǎn)義語(yǔ)法,該語(yǔ)法允許對(duì)所有 RDBMS 使用標(biāo)準(zhǔn)方式調(diào)用存儲(chǔ)過(guò)程。此轉(zhuǎn)義語(yǔ)法有一個(gè)包含結(jié)果參數(shù)的形式和一個(gè)不包含結(jié)果參數(shù)的形式。如果使用結(jié)果參數(shù),則必須將其注冊(cè)為 OUT 參數(shù)。其他參數(shù)可用于輸入、輸出或同時(shí)用于二者。參數(shù)是根據(jù)編號(hào)按順序引用的,第一個(gè)參數(shù)的編號(hào)是 1。

       {?= call <procedure-name>[(<arg1>,<arg2>, ...)]}
       {call <procedure-name>[(<arg1>,<arg2>, ...)]}

     IN 參數(shù)值是使用繼承自 PreparedStatement 的 set 方法設(shè)置的。在執(zhí)行存儲(chǔ)過(guò)程之前,必須注冊(cè)所有 OUT 參數(shù)的類(lèi)型;它們的值是在執(zhí)行后通過(guò)此類(lèi)提供的 get 方法獲取的。

    CallableStatement 可以返回一個(gè) ResultSet 對(duì)象或多個(gè) ResultSet 對(duì)象。多個(gè) ResultSet 對(duì)象是使用繼承自 Statement 的操作處理的。

    posted on 2008-10-04 22:13 黃小二 閱讀(1263) 評(píng)論(3)  編輯  收藏 所屬分類(lèi): S/S2SH

    評(píng)論:
    # re: [轉(zhuǎn)] Hibernate3.0以上中執(zhí)行存儲(chǔ)過(guò)程[未登錄](méi) 2010-01-16 16:46 | AAA
    第二種方式如何獲得返回值啊??  回復(fù)  更多評(píng)論
      
    # re: [轉(zhuǎn)] Hibernate3.0以上中執(zhí)行存儲(chǔ)過(guò)程[未登錄](méi) 2010-01-16 16:47 | AAA
    返回值不是一個(gè)結(jié)果集的!  回復(fù)  更多評(píng)論
      
    # re: [轉(zhuǎn)] Hibernate3.0以上中執(zhí)行存儲(chǔ)過(guò)程 2011-12-29 15:31 | binbinaccp
    conn.prepareCall("{Call pro_getManager(?,?)}");
    我寫(xiě)這句為什么編譯報(bào)錯(cuò)?  回復(fù)  更多評(píng)論
      
    主站蜘蛛池模板: 国产桃色在线成免费视频 | 91香蕉在线观看免费高清| 亚洲影院在线观看| 香蕉高清免费永久在线视频 | 亚洲成a人片7777| 噜噜噜亚洲色成人网站∨| 人妻在线日韩免费视频| 久久久青草青青国产亚洲免观| 久久国产精品免费视频| 亚洲中文字幕久久精品无码喷水| 免费v片在线观看视频网站| 午夜亚洲国产理论秋霞| 老司机69精品成免费视频| 日本一道一区二区免费看| 免费一级全黄少妇性色生活片 | 一区二区三区观看免费中文视频在线播放 | 边摸边吃奶边做爽免费视频网站 | 国产精品1024在线永久免费| 亚洲色婷婷综合开心网| 亚洲精品视频在线播放| 18国产精品白浆在线观看免费 | jyzzjyzz国产免费观看| 亚洲综合图色40p| 99精品热线在线观看免费视频| 永久免费av无码网站yy| 亚洲国产精品热久久| 黑人粗长大战亚洲女2021国产精品成人免费视频 | 16女性下面无遮挡免费| 亚洲深深色噜噜狠狠网站| 任你躁在线精品免费| 成人永久免费福利视频网站| 一本大道一卡二大卡三卡免费| 99国产精品免费视频观看| 亚洲sss综合天堂久久久| 又爽又高潮的BB视频免费看 | 国产精品亚洲mnbav网站| 四虎国产成人永久精品免费| 亚洲一日韩欧美中文字幕在线 | 一级女性全黄生活片免费看| 亚洲欧洲自拍拍偷午夜色无码| 亚洲国产高清国产拍精品|