小男孩‘自慰网亚洲一区二区,亚洲一级在线播放毛片,亚洲中文字幕av每天更新,黄aⅴ永久免费无码,91成人午夜在线精品,色网站免费在线观看,亚洲欧洲wwwww在线观看

分享

利用Jakarta Commons組件beanutils、dbutils簡(jiǎn)化JDBC數(shù)據(jù)庫(kù)操作(一)

 小朋 2006-10-20
利用Jakarta Commons組件beanutils、dbutils簡(jiǎn)化JDBC數(shù)據(jù)庫(kù)操作(一)
hyysguyang 原創(chuàng)  (參與分:6032,專家分:261)   發(fā)表:2005-12-20 18:42   更新:2006-04-01 17:57   版本:1.0   閱讀:986

關(guān)鍵字:beanutils、dbutils、JDBC 數(shù)據(jù)庫(kù)
摘要:本文簡(jiǎn)單介紹了Jakarta Commons旗下beanutils、dbutils在基于JDBC API數(shù)據(jù)庫(kù)存取操作中的運(yùn)用。
    雖然現(xiàn)在出現(xiàn)了很多ORM框架,可是還是有很多朋友也許還在使用JDBC,就像我現(xiàn)在一樣,除了學(xué)習(xí)的時(shí)候在使用Hibernate、Spring類似這 些優(yōu)秀的框架,工作時(shí)一直都在使用JDBC。本文就簡(jiǎn)單介紹一下利用Jakarta Commons旗下beanutils、dbutils簡(jiǎn)化JDBC 數(shù)據(jù)庫(kù)操作,以拋磚引玉,希望對(duì)像我一樣在使用JDBC的朋友有所幫助。
    下面就分兩部分簡(jiǎn)單介紹beanutils、dbutils在基 于JDBC API數(shù)據(jù)庫(kù)存取操作中的運(yùn)用。第一部分顯介紹beanutils在JDBC數(shù)據(jù)庫(kù)存取操作中的運(yùn)用,第二部分介紹dbutils在JDBC 數(shù)據(jù)庫(kù)存取操作中的運(yùn)用,最后看看他們的優(yōu)缺點(diǎn),談?wù)劚救嗽陧?xiàng)目運(yùn)用過程中對(duì)他們的一點(diǎn)心得體會(huì),僅供參考,其中有錯(cuò)誤的地方希望大蝦不吝賜教,大家多多 交流共同進(jìn)步。
一、Jakarta Commons beanutils
    Beanutils是操作Bean的銳利武器,其提過的 BeanUtils工具類可以簡(jiǎn)單方便的讀取或設(shè)置Bean的屬性,利用Dyna系列,還可以在運(yùn)行期創(chuàng)建Bean,符合懶人的習(xí)慣,正如 LazyDynaBean,LazyDynaClass一樣,呵呵。這些用法已經(jīng)有很多文章提及,也可以參考apache的官方文檔。
    對(duì) 于直接利用JDBC API訪問數(shù)據(jù)庫(kù)時(shí)(這里針對(duì)的是返回結(jié)果集ResultSet的查詢select),大多數(shù)都是采用兩種方式,一種是取出返回的結(jié) 果集的數(shù)據(jù)存于Map中,另一種方式是Bean里。針對(duì)第二種方式,Beanutils里提供了ResultSetDynaClass結(jié)合 DynaBean以及RowSetDynaClass結(jié)合DynaBean來(lái)簡(jiǎn)化操作。下面用以個(gè)簡(jiǎn)單的例子展示一下beanutils的這兩個(gè)類在 JDBC數(shù)據(jù)庫(kù)操作中的運(yùn)用。
    請(qǐng)?jiān)诒緳C(jī)建立數(shù)據(jù)庫(kù)publish,我用的是MySQL,在publish數(shù)據(jù)庫(kù)中建立表book,腳本如下:
CREATE TABLE book(
  id int(11) NOT NULL auto_increment,
  title varchar(50) character set latin1 NOT NULL,
  authors varchar(50) character set latin1 default NULL, 
  PRIMARY KEY  (id)


     然后用你喜歡的編輯器建立一個(gè)類BeanutilsJDBCTest,我們先用ResultSetDynaClass來(lái)處理,然后再用 RowSetDynaClass來(lái)實(shí)現(xiàn)同樣的類,之后看看他們之間有什么不同,用ResultSetDynaClass處理的源代碼如下所示:
     然后用你喜歡的編輯器建立一個(gè)類BeanutilsJDBCTest,我們先用ResultSetDynaClass來(lái)處理,然后再用 RowSetDynaClass來(lái)實(shí)現(xiàn)同樣的類,之后看看他們之間有什么不同,用ResultSetDynaClass處理的源代碼如下所示:
package cn.qtone.test;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;
import java.util.Iterator; 
import org.apache.commons.beanutils.DynaBean;
import org.apache.commons.beanutils.PropertyUtils;
import org.apache.commons.beanutils.ResultSetDynaClass; 
public class BeanutilsJDBCTest{
       public static void main(String[] args) {
              Connection con = null;
              Statement st = null;
              ResultSet rs = null;
              try {
                     Class.forName("com.mysql.jdbc.Driver");
                     String url = "jdbc:mysql://127.0.0.1:3306/publish?useUnicode=true&characterEncoding=GBK";
                     con = DriverManager.getConnection(url, "root", "hyys");
                     st = con.createStatement();
                     rs = st.executeQuery("select * from book");
                     ResultSetDynaClass rsDynaClass = new ResultSetDynaClass(rs);
                     Iterator itr = rsDynaClass.iterator();
                     System.out.println("title-------------authors");
                     while (itr.hasNext()) {
                            DynaBean dBean = (DynaBean) itr.next();
                            System.out.println(PropertyUtils.getSimpleProperty(dBean,"title")+ "-------"+ PropertyUtils.getSimpleProperty(dBean, "authors"));

                     }
              } catch (Exception e) {
                     e.printStackTrace();
              } finally {
                     try {
                            if (rs != null) {
                                   rs.close();
                            }
                            if (st != null) {
                                   st.close();
                            }
                            if (con != null) {
                                   con.close();
                            }
                     } catch (Exception e) {
                            e.printStackTrace();
                     }
              }
       }


用RowSetDynaClass處理的源代碼如下所示: 

package cn.qtone.test; 

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;
import java.util.Iterator;
import java.util.List; 
import org.apache.commons.beanutils.DynaBean;
import org.apache.commons.beanutils.PropertyUtils;
import org.apache.commons.beanutils.RowSetDynaClass; 

public class BeanutilsJDBCTest{
       public static void main(String[] args) {
              List rsDynaClass = rsTest();
              System.out.println("title ------------- authors ");
              Iterator itr = rsDynaClass.iterator();
              while (itr.hasNext()) {
                     DynaBean dBean = (DynaBean) itr.next();
                     try {
                            System.out.println(PropertyUtils.getSimpleProperty(dBean,"name")  + "-----"+ PropertyUtils.getSimpleProperty(dBean, "mobile"));
                     } catch (Exception e) {
                            // TODO 自動(dòng)生成 catch 塊
                            e.printStackTrace();
                     }
              }
       } 
       private static List rsTest() {
              Connection con = null;
              Statement st = null;
              ResultSet rs = null;
              try {
                     Class.forName("com.mysql.jdbc.Driver");
                     String url = "jdbc:mysql://127.0.0.1:3306/publish?useUnicode=true&characterEncoding=GBK";
                     con = DriverManager.getConnection(url, "root", "hyys");
                     st = con.createStatement();
                     rs = st.executeQuery("select * from book");
                     RowSetDynaClass rsdc = new RowSetDynaClass(rs);
                     return rsdc.getRows();
              } catch (Exception e) {
                     e.printStackTrace();
              } finally {
                     try {
                            if (rs != null) {
                                   rs.close();
                            }
                            if (st != null) {
                                   st.close();
                            }
                            if (con != null) {
                                   con.close();
                            }
                     } catch (Exception e) {
                            e.printStackTrace();
                     }
              }
              return null;
       }


     這兩個(gè)方法輸出的結(jié)果應(yīng)該是一樣的。但是很顯然第二種方式比第一種方式要好,它把數(shù)據(jù)訪問部分抽取出來(lái)放到一個(gè)方法中,顯得簡(jiǎn)單清晰。
      其實(shí)在利用ResultSetDynaClass時(shí),必須在ResultSet等數(shù)據(jù)庫(kù)資源關(guān)閉之前,處理好那些數(shù)據(jù),你不能在資源關(guān)閉之后使用 DynaBean,否則就會(huì)拋出異常,異常就是說(shuō)不能在ResultSet之后存取數(shù)據(jù)(具體的異常名我也忘了),當(dāng)然你也可以采用以前的方式一個(gè)一個(gè)的 把數(shù)據(jù)放到Map里,如果你一定要那樣做,建議還是別用Beanutils,因?yàn)檫@沒帶給你什么好處??傊肦esultSetDynaClass你的 程序的擴(kuò)展性非常部好。
    從第二中方式可以看出,利用RowSetDynaClass可以很好的解決上述 ResultSetDynaClass遇到的問題,RowSetDynaClass的getRows()方法,把每一行封裝在一個(gè)DynaBean對(duì)象 里,然后,把說(shuō)有的行放到一個(gè)List里,之后你就可以對(duì)返回的List里的每一個(gè)DynaBean進(jìn)行處理,此外對(duì)于DynaBean你還可以采用標(biāo)準(zhǔn) 的get/set方式處理,當(dāng)然你也可以用PropertyUtils. getSimpleProperty(Object bean,  String name)進(jìn)行處理。
    從上面的分析中,你應(yīng)該可以決定你應(yīng)該使用ResultSetDynaClass還是RowSetDynaClass了。

    本站是提供個(gè)人知識(shí)管理的網(wǎng)絡(luò)存儲(chǔ)空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請(qǐng)注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購(gòu)買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊一鍵舉報(bào)。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評(píng)論

    發(fā)表

    請(qǐng)遵守用戶 評(píng)論公約

    類似文章 更多