Eclipse快速上手Hibernate--1. 入門實(shí)例 (轉(zhuǎn))
Posted on 2006-12-04 02:13 笨蛋啊帆 閱讀(536) 評(píng)論(0) 編輯 收藏?
??? 這篇文章主要談?wù)凥ibernate的入門開發(fā),例子很簡(jiǎn)單,就是向數(shù)據(jù)表中添加用戶名和密碼。我分別使用了三種方法,一種是直接寫代碼,寫Hbm映射文件等;一種是通過Hbm映射文件來生成代碼;一種是通過代碼來生成Hbm映射文件。使用了一些自動(dòng)化工具,XMLBuddy是用來編輯XML文件的, JBoss Eclipse IDE是用來編寫Doclet標(biāo)記的。這篇文章還談到了一些Eclipse的使用技巧,比如建立“用戶庫”、“生成 Getter 和 Setter”等。
?
?? 關(guān)于一些軟件的使用技巧,我以前的文章都有提及,這里不多說了,必要時(shí)會(huì)提示一下。
???
?
?
1. 所需軟件
● Ant 1.6.2????????http://ant.apache.org
????下載??????????? http://mirror.apache.or.kr/ant/binaries/apache-ant-1.6.2-bin.zip
?
●?Eclipse 3.0.1?及 語言包
??? 參考:????????? http://blog.csdn.net/javamxj/archive/2004/10/11/131952.aspx
?
● XDoclet? 1.2.2?? http://xdoclet.sourceforge.net/xdoclet/
?
● XMLBuddy???????? ?http://www.xmlbuddy.com/
??? 下載???????????? XMLBuddy 2.0.38???
?
● JBoss Eclipse IDE?http://www.jboss.org/products/jbosside
?? 看看說明,需要挑選與使用的eclipse相對(duì)應(yīng)的版本,這里選擇JBossIDE-1.4.1-e30.zip,這是它的鏡像下載地址:
?
● Hibernate???????? http://www.hibernate.org/
?????下載???????????
Hibernate 2.1.8
?
?? 同時(shí)也要把 Hibernate Extensions 2.1.3 下載了,它包含一些工具類。
???? 下載??????????? http://prdownloads.sourceforge.net/hibernate/hibernate-extensions-2.1.3.zip?download
?
?
●?
MySQL?4.1.8
???? 注意需要mysql-connector-java-3.0.16-ga-bin.jar文件
?
?
?
2. 安裝和配置?
?
??? 這里著重指出一下,需要在環(huán)境變量中設(shè)置 ANT_HOME ,并將其指向Ant安裝目錄,還要在Path變量值中添加 “%ANT_HOME%\bin;” 可以參考 java環(huán)境變量設(shè)置 。
?
?· XMLBuddy?和Jboss-ide 我都是采用links方式安裝的,
?
●?
建立庫文件夾:
?
?? 在D盤下新建一個(gè)java目錄,在此目錄下新建一個(gè)Hibernate子目錄,在此子目錄下再新建一個(gè)lib子目錄。
D:\
??-java
???? -Hibernate
?????????????? -lib
?
· 將下載的hibernate-2.1.8.zip解壓,如解壓后的目錄名為hibernate-2.1,將這個(gè)目錄下的hibernate2.jar復(fù)制到先前建立的lib目錄下,即D:\java\Hibernate\lib目錄;
?
?· 然后將hibernate-2.1目錄下的lib子目錄中的以下文件也復(fù)制到這個(gè)lib目錄下:
jta.jar?
cglib-full-2.0.2.jar?
commons-collections-2.1.1.jar?
commons-logging-1.0.4.jar
commons-lang-1.0.1.jar?
dom4j-1.4.jar
ehcache-0.9.jar
log4j-1.2.8.jar
odmg-3.0.jar
odmg-3.0.jar
?
?·?解壓hibernate-extensions-2.1.3.zip,將其子目錄tools中的hibernate-tools.jar和子目錄lib中的
velocity-1.3.1.jar、jdom.jar也復(fù)制到D:\java\Hibernate\lib目錄中
?
?·? 解壓xdoclet-bin-1.2.2.zip,將其子目錄lib中的xdoclet-1.2.2.jar、xdoclet-hibernate- module-1.2.2.jar、xjavadoc-1.1.jar、xdoclet-xdoclet-module-1.2.2.jar 也復(fù)制到D:\java\Hibernate\lib目錄中
?
· 最后將mysql-connector-java-3.0.16-ga-bin.jar文件復(fù)制到這個(gè)lib目錄下。
?
?? 這樣,需要用到的庫文件已經(jīng)準(zhǔn)備好了,如果認(rèn)為這樣比較麻煩,也可以將jar文件全部復(fù)制到lib目錄。下面介紹如何在Eclipse中設(shè)置“用戶庫”。
?
?
?
●? 設(shè)置“用戶庫”
?
·
窗口 ->首選項(xiàng) ->Java ->構(gòu)建路徑 ->用戶庫,

?
·
然后單擊“添加JAR”

?
?? 這樣,一個(gè)用戶庫文件就做好了,如果要更新Eclipse時(shí),可以將其先導(dǎo)出,然后再導(dǎo)入即可。
這樣做,對(duì)庫文件便于管理,而且如果需要替換或者升級(jí)的話都比較方便。
?
?
●? 設(shè)置“構(gòu)建路徑”
?
· 點(diǎn)擊菜單“窗口”->首選項(xiàng),以下都在“首選項(xiàng)”中配置:
?? Java->構(gòu)建路徑
??

?
?
?
?
?
??? 這里以一個(gè)簡(jiǎn)單的程序來示范Hibernate的配置與功能,在這個(gè)例子中的一些操作,實(shí)際上會(huì)使用一些自動(dòng)化工具來完成,而不一定親自手動(dòng)操作設(shè)定,這邊完全手動(dòng)的原因,在于讓你可以知道Hibernate的基本流程。
???? 這是整個(gè)項(xiàng)目的結(jié)構(gòu):

好了,下面就開始創(chuàng)建項(xiàng)目了。
??
?
1. 創(chuàng)建項(xiàng)目
?
·
新建一個(gè)Java項(xiàng)目:HibernateBegin_1,注意選中“創(chuàng)建單獨(dú)的源文件夾和輸出文件夾”。點(diǎn)擊“下一步”,切換到“庫”,點(diǎn)擊“添加庫”,如下圖:

?
·
選擇“用戶庫”

?
·
勾選先前設(shè)置好的hibernate用戶庫。

?
?
2. 建立可持久化類?
?
·
下面開始創(chuàng)建一個(gè)新類:User ;包名:javamxj.hibernate ;
然后添加三個(gè)變量(斜體),代碼如下:
/* * 采用常規(guī)方法開發(fā)一個(gè)簡(jiǎn)單的Hibernate實(shí)例 * 創(chuàng)建日期 2005-3-31 * @author javamxj(分享java快樂) * @link Blog: htpp://javamxj.mblogger.cn * htpp://blog.csdn.net/javamxj/ */ package javamxj . hibernate ; public class User { private int id; privateString username; privateString password; }
·
點(diǎn)擊工具欄上的“源代碼(S)”,選擇其中的“生成 Getter 和 Setter”(右擊,在彈出菜單也可選擇),如圖:

?
點(diǎn)擊“確定”后,生成如下代碼:
/* * 采用常規(guī)方法開發(fā)一個(gè)簡(jiǎn)單的Hibernate實(shí)例 * 創(chuàng)建日期 2005-3-31 * @author javamxj(分享java快樂) * @link Blog: htpp://javamxj.mblogger.cn * htpp://blog.csdn.net/javamxj/ */ package javamxj . hibernate ; public class User { privateint id; privateString username; privateString password; public int getId() { return id; } publicvoid setId(int id) { this.id = id; } publicString getPassword() { return password; } publicvoid setPassword(String password) { this.password = password; } publicString getUsername() { return username; } publicvoid setUsername(String username) { this.username = username; }}
?
??? 好了,這個(gè)類完成了。它是一個(gè)普通的Java對(duì)象(Plain Old Java Objects,就是POJOs,有時(shí)候也稱作Plain Ordinary Java Objects),表示一個(gè)數(shù)據(jù)集合。下面建立一個(gè)Hbm文件將這個(gè)類映射到數(shù)據(jù)庫的表格上。
?
?
3. 映射文件
?
?? 在javamxj.hibernate包下,新建一個(gè)名稱為“User.hbm.xml”的文件,使用XMLBuddy編輯它(參考:利用XMLBuddy在Eclipse中開發(fā)XML?),這樣比較方便。文件內(nèi)容如下:
<? xml version="1.0" encoding="GBK"?><!DOCTYPEhibernate-mappingPUBLIC"-//Hibernate/Hibernate Mapping DTD//EN""http://hibernate.sourceforge.net/hibernate-mapping-2.0.dtd"><hibernate-mapping><class name="javamxj.hibernate.User" table="UserTable"><id name="id"><generator class="assigned"/></id><property name="username"/><property name="password"/></class></hibernate-mapping>
??? 這個(gè)XML文件定義了對(duì)象屬性映射到數(shù)據(jù)庫表的關(guān)系,這里采用了assigned(程序設(shè)置)方式生成主鍵。當(dāng)然還可以使用其它的方式來產(chǎn)生主鍵,后面的文章就采用了其它的方式產(chǎn)生主鍵。
?
???< property>標(biāo)簽用于定義Java對(duì)象的屬性,這里只定義了最簡(jiǎn)單的方式,由Hibernate自動(dòng)判斷Java對(duì)象屬性與數(shù)據(jù)庫表名稱對(duì)應(yīng)關(guān)系。在<property/>標(biāo)簽上的額外設(shè)定(像是not null、sql-type等),則可以用于自動(dòng)產(chǎn)生Java對(duì)象與數(shù)據(jù)庫表的工具上。
?
?
4. 配置文件
?
?? Hibernate可以使用XML或?qū)傩晕募磉M(jìn)行配置,配置文件名默認(rèn)為“hibernate.cfg.xml”(或者h(yuǎn)ibernate.properties)。
?? 在src目錄下,新建一個(gè)hibernate.cfg.xml文件,內(nèi)容如下:
<? xml version='1.0' encoding='GBK'?><!DOCTYPEhibernate-configurationPUBLIC"-//Hibernate/Hibernate Configuration DTD//EN""http://hibernate.sourceforge.net/hibernate-configuration-2.0.dtd"><hibernate-configuration><session-factory><!-- 是否將運(yùn)行期生成的SQL輸出到日志以供調(diào)試 --><property name="show_sql">true</property><!-- SQL方言,這里設(shè)定的是MySQL --><property name="dialect">net.sf.hibernate.dialect.MySQLDialect</property><!-- JDBC驅(qū)動(dòng)程序 --><property name="connection.driver_class">com.mysql.jdbc.Driver</property><!-- JDBC URL, "?useUnicode=true&characterEncoding=GBK" 表示使用GBK進(jìn)行編碼 --><property name="connection.url"> jdbc:mysql://localhost:3306/HibernateTest?useUnicode=true&characterEncoding=GBK</property><!-- 數(shù)據(jù)庫用戶名 --><property name="connection.username">root</property><!-- 數(shù)據(jù)庫密碼 --><property name="connection.password">javamxj</property><!-- 指定User的映射文件 --><mapping resource="javamxj/hibernate/User.hbm.xml"/></session-factory></hibernate-configuration>
?
注意:這里使用的是“jdbc:mysql://localhost:3306/HibernateTest?useUnicod...”中的HibernateTest數(shù)據(jù)庫,你需要在MySql中建立這個(gè)數(shù)據(jù)庫。
?
?
5. 測(cè)試程序
?
?? 在javamxj.hibernate包下,新建一個(gè)Test類,內(nèi)容如下:
/* * 簡(jiǎn)單測(cè)試一下User類 * 創(chuàng)建日期 2005-3-31 * @author javamxj(分享java快樂) */ package javamxj . hibernate ; import net . sf . hibernate . * ; import net . sf . hibernate . cfg . * ; public class Test { publicstaticvoid main(String[] args) { try { SessionFactory sf = new Configuration().configure() .buildSessionFactory(); Session session = sf.openSession(); Transaction tx = session.beginTransaction(); User user = new User(); user.setUsername("Blog"); user.setPassword("分享java快樂"); session.save(user); tx.commit(); session.close(); } catch (HibernateException e) { e.printStackTrace(); } }}
?
??? 這里簡(jiǎn)單說說一下流程,首先初始化Configuration,加載Hibernate的配置信息,然后Configuration取得 SessionFactory對(duì)象,并由它來開啟一個(gè)Session,它代表對(duì)象與表格的一次會(huì)話操作,而 Transaction則表示一組會(huì)話操作,我們只需要直接操作User對(duì)象,并進(jìn)行Session與Transaction的相關(guān)操作, Hibernate就會(huì)自動(dòng)完成對(duì)數(shù)據(jù)庫的操作。
?
?
6. 配置數(shù)據(jù)庫
?
?? 在運(yùn)行測(cè)試程序之前,還必須先設(shè)置好數(shù)據(jù)庫。
?? 在MySQL中建立一個(gè)HibernateTest數(shù)據(jù)庫,并建立UserTable表,SQL語句如下:
?
CREATETABLE usertable (
? ID int(6) NOTNULL auto_increment,
? username varchar(24) NOTNULLdefault'',
??password varchar(24) NOTNULLdefault'',
? PRIMARYKEY? (ID)
);
? ID int(6) NOTNULL auto_increment,
? username varchar(24) NOTNULLdefault'',
??password varchar(24) NOTNULLdefault'',
? PRIMARYKEY? (ID)
);
??? 這里,HibernateTest與hibernate.cfg.xml配置文件中的HibernateTest相對(duì)應(yīng),UserTable與hbm映射文件中的UserTable相對(duì)應(yīng)。
?
?
7. 運(yùn)行程序
?
?? 右擊Test.java,點(diǎn)擊運(yùn)行,可以看到控制臺(tái)輸出一系列信息,最后一條輸出語句應(yīng)該是:
Hibernate: insert into UserTable (username, password, id) values (?, ?, ?)
?? 在下篇文章中會(huì)介紹如何利用log4j來控制輸出信息。
?
?? 同時(shí),在數(shù)據(jù)庫中可以看到,數(shù)據(jù)已經(jīng)添加進(jìn)表里了:

?