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

          都市淘沙者

          荔枝FM Everyone can be host

          統(tǒng)計(jì)

          留言簿(23)

          積分與排名

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

          友情連接

          閱讀排行榜

          評(píng)論排行榜

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

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

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

          如果真的要獲得查詢數(shù)據(jù)庫的結(jié)果集,就把結(jié)果集對(duì)象內(nèi)的所有數(shù)據(jù),轉(zhuǎn)儲(chǔ)到以Map為元素的List對(duì)象內(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
          {// 定義連接池對(duì)象為靜態(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ū)動(dòng)獲得連接// 相關(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.對(duì)于insert, update, delete語句
          int count = DbWrapper.executeUpdate(sql);
          // 2.對(duì)于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());

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

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

          評(píng)論

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

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

          主站蜘蛛池模板: 确山县| 宣武区| 沁源县| 祁阳县| 锦屏县| 济源市| 甘泉县| 浙江省| 寿光市| 蒙自县| 永城市| 五华县| 安宁市| 涿州市| 教育| 邯郸县| 高淳县| 集安市| 临城县| 横山县| 巴中市| 舞钢市| 东阳市| 新乐市| 错那县| 吴江市| 平凉市| 郴州市| 东港市| 洪江市| 台南县| 乐山市| 伊春市| 柞水县| 浮山县| 林口县| 工布江达县| 临汾市| 广丰县| 黄石市| 津市市|