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

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

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

    隨筆-7  評論-24  文章-102  trackbacks-0

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

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

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

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

    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)閉會話
      }


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

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

    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 接口功能很強大吧


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

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

     

    public interface CallableStatement extends PreparedStatement

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

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

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

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

    posted on 2008-10-04 22:13 黃小二 閱讀(1257) 評論(3)  編輯  收藏 所屬分類: S/S2SH

    評論:
    # re: [轉(zhuǎn)] Hibernate3.0以上中執(zhí)行存儲過程[未登錄] 2010-01-16 16:46 | AAA
    第二種方式如何獲得返回值啊??  回復(fù)  更多評論
      
    # re: [轉(zhuǎn)] Hibernate3.0以上中執(zhí)行存儲過程[未登錄] 2010-01-16 16:47 | AAA
    返回值不是一個結(jié)果集的!  回復(fù)  更多評論
      
    # re: [轉(zhuǎn)] Hibernate3.0以上中執(zhí)行存儲過程 2011-12-29 15:31 | binbinaccp
    conn.prepareCall("{Call pro_getManager(?,?)}");
    我寫這句為什么編譯報錯?  回復(fù)  更多評論
      
    主站蜘蛛池模板: 一级做α爱过程免费视频| 亚洲a∨无码精品色午夜| 91亚洲va在线天线va天堂va国产| 久久精品国产亚洲AV网站| 亚洲制服丝袜精品久久| 亚洲av日韩专区在线观看| 免费观看理论片毛片| 亚洲综合另类小说色区| 久久亚洲AV无码精品色午夜| 国产精品区免费视频| 毛色毛片免费观看| 国产亚洲av人片在线观看| xxxxxx日本处大片免费看 | 好吊妞在线成人免费| 久久精品亚洲中文字幕无码网站 | 精品亚洲av无码一区二区柚蜜| 中文字字幕在线高清免费电影| 久久久久久精品免费免费自慰| 免费少妇a级毛片人成网| 亚洲午夜久久久精品影院| 男人扒开添女人下部免费视频| 亚洲免费观看网站| 亚洲精品国产精品国自产网站| 中文字幕在线观看免费| 亚洲一区二区三区高清| a级毛片免费全部播放| 五月天婷亚洲天综合网精品偷| 亚洲一卡2卡3卡4卡国产网站| 99精品视频在线视频免费观看| 亚洲国产精品一区二区第四页| 国产亚洲精品bv在线观看| 四虎最新永久免费视频| 午夜亚洲国产理论片二级港台二级| 亚洲高清最新av网站| 无码人妻久久一区二区三区免费 | 69式互添免费视频| 菠萝菠萝蜜在线免费视频| 国产麻豆免费观看91| 亚洲AV日韩AV永久无码绿巨人| eeuss影院ss奇兵免费com| 国产三级电影免费观看|