Dict.CN 在線詞典, 英語學(xué)習(xí), 在線翻譯

          都市淘沙者

          荔枝FM Everyone can be host

          統(tǒng)計(jì)

          留言簿(23)

          積分與排名

          優(yōu)秀學(xué)習(xí)網(wǎng)站

          友情連接

          閱讀排行榜

          評論排行榜

          將數(shù)據(jù)庫操作封裝到Javabean

          封裝數(shù)據(jù)庫操作,目的就是為了隱藏java.sql包內(nèi)的類,在編碼中去掉核心的數(shù)據(jù)庫操作代碼。以杜絕直接數(shù)據(jù)庫操作容易帶來的資源未釋放問題。同時也減少了數(shù)據(jù)庫操作的編碼量。

          但是很多網(wǎng)友在封裝時,卻喜歡返回結(jié)果集(ResultSet對象),那么這個封裝就沒有意義了。
          1. 又是直接操作核心數(shù)據(jù)庫類,跟封裝前幾乎沒什么變化。
          2. 結(jié)果集總是依賴于它使用的連接(Connection)對象。因此當(dāng)連接對象在方法內(nèi)被關(guān)閉后,你返回的ResultSet就沒有用了。

          如果真的要獲得查詢數(shù)據(jù)庫的結(jié)果集,就把結(jié)果集對象內(nèi)的所有數(shù)據(jù),轉(zhuǎn)儲到以Map為元素的List對象內(nèi)。
          當(dāng)然,這種方式,不能適應(yīng)大數(shù)據(jù)量的查詢,不過如果真的碰到大數(shù)據(jù)量的查詢,那用什么封裝都不好,還是得直接數(shù)據(jù)庫操作. :)))

          下面是簡單的數(shù)據(jù)庫操作Javabean的代碼

          DbWrapper.java
          												
          														
          																import
          														 java.sql.*;import java.util.*;publicclass DbWrapper
          {// 定義連接池對象為靜態(tài)變量,將一直存在,直到工作目錄關(guān)閉。privatestatic DataSource ds =null;
          // 1.用連接池的方式獲得連接// 如果不是做多數(shù)據(jù)庫程序,推薦使用此方法// 相關(guān)內(nèi)容:在tomcat管理界面配置連接池publicstatic Connection openConnection()throws Exception {// 只需要初始化1次if( ds ==null){ Context initContext =newInitialContext(); Context envContext =(Context) initContext.lookup("java:/comp/env"); DataSource ds =(DataSource) envContext.lookup("jdbc/MyDataSource");}return ds.getConnection();}// 2.用jdbc驅(qū)動獲得連接// 相關(guān)內(nèi)容:JSP數(shù)據(jù)庫連接大全publicstatic Connection openConnection( String driver, String url, String username, String password)throws Exception { Class.forName(driver).newInstance();return DriverManager.getConnection(url, username, password);}publicstaticvoidcloseConnection(Connection conn)throws Exception {if( conn !=null){ conn.close();}}
          publicstaticintexecuteUpdate(String sql)throws Exception {int count =0; Connection conn =null; Statement stmt =null;try{ conn =openConnection(); stmt = conn.createStatement(); count = stmt.executeUpdate(sql);}catch( Exception e ){throw e;}finally{closeConnection(conn);}return count;}publicstatic List executeQuery(String sql)throws Exception { List list =newArrayList(); Connection conn =null; Statement stmt =null; ResultSet rs =null;try{ conn =openConnection(); stmt = conn.createStatement(); rs = stmt.executeQuery(sql); ResultSetMetaData rsmd = rs.getMetaData();while( rs.next()){ Map map =newHashMap();for(int i =1; i <= rsmd.getColumnCount(); i++){ map.put(rsmd.getColumnName(i), rs.getObject(i));} list.add(map);}
          }catch( Exception e ){ e.printStackTrace();}finally{if( rs !=null) rs.close();closeConnection(conn);}return list;
          }}


          使用示例:
          // 1.對于insert, update, delete語句
          int count = DbWrapper.executeUpdate(sql);
          // 2.對于selete語句 java.util.List list = DbWrapper.executeQuery(sql);
          // 方法一:按名字取值,注意大小寫是嚴(yán)格區(qū)分的for(int i =0; i < list.size(); i++){ java.util.Map map =(java.util.Map)list.get(i); out.println(mag.get("column_name").toString());}
          // 方法二:遍歷取值for(int i =0; i < list.size(); i++){ java.util.Map map =(java.util.Map)list.get(i);
          for(java.util.Iterator it = map.keySet().iterator(); it.hasNext();){ String column_name = it.next().toString());

          // 取值時注意null判斷 out.println(column_name +" = "+ map.get(column_name) ==null?"": map.get(column_name).toString());}}

          posted on 2006-04-26 16:02 都市淘沙者 閱讀(282) 評論(1)  編輯  收藏 所屬分類: Java Basic/Lucene/開源資料

          評論

          # re: 將數(shù)據(jù)庫操作封裝到Javabean [未登錄] 2008-03-28 22:11 小蝦米

          有這么復(fù)雜嗎?看的眼花繚亂。新建一個BEAN類。然后在連接數(shù)據(jù)庫類中NEW一個BEAN對象。在SET下返回!  回復(fù)  更多評論   

          主站蜘蛛池模板: 呼玛县| 马公市| 凉城县| 马山县| 霍林郭勒市| 闵行区| 安康市| 营口市| 蒙阴县| 和田县| 乌恰县| 正镶白旗| 永嘉县| 赞皇县| 海宁市| 鹤山市| 麻江县| 锦屏县| 翁源县| 伊川县| 仙居县| 平泉县| 营山县| 滁州市| 榆林市| 富民县| 奉贤区| 云南省| 锦州市| 来宾市| 临漳县| 福清市| 筠连县| 清河县| 朔州市| 松江区| 霍邱县| 宜阳县| 清丰县| 莱州市| 上虞市|