隨筆-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 使用標(biāo)準(zhǔn)方式調(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 黃小二 閱讀(1258) 評論(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ù)  更多評論
            
          主站蜘蛛池模板: 杭州市| 内江市| 霍邱县| 泰安市| 咸宁市| 英山县| 河曲县| 喜德县| 定安县| 方正县| 大姚县| 濮阳县| 北京市| 遂昌县| 江北区| 建水县| 宕昌县| 山东省| 株洲市| 桃江县| 鄯善县| 龙里县| 恩施市| 桦南县| 枣阳市| 石首市| 孟州市| 土默特左旗| 特克斯县| 克拉玛依市| 鹤山市| 鄂伦春自治旗| 罗山县| 青冈县| 甘洛县| 荣成市| 托克逊县| 万盛区| 家居| 洪江市| 麦盖提县|