一、下載hibernate-3.2 core版本,解壓。
二、打開eclipse,建立一個用戶庫,命名爲:hibernate3.2,導入剛解壓的hibernate目錄下的hibernate3.jar
並\lib目錄下的所有jar文件。在Builder path的source and output fold中選擇Folder,並默認給出的文件夾名。
在as JRE library use中選擇JRE_LIB variable。
三、新建一個java工程。在其屬性的Java Build Path中引入剛建立的hibernate3.2用戶庫並mysql的java驅動(
視你所用的數據庫而定,在這我用的是mysql數據庫)。
四、在src中建立一個包,設爲px.malijun,並在其中建立以下幾個Java Class:
建立相應的xml映射文件:
在數據庫中建立一個myproject(按你的意思定名)數據庫,在其中建立一個users表(向RoR學習):
注:我是用phpmyadmin對mysql數據庫進行管理的,在建立的時候我特意爲其選擇了utf-8編碼。
在src的根目錄下(以上的user.hbm.xml映射文件與User.java在同一目錄下)建立hibernate的配置文件:
ok 了,下面我們就進入我們的實際使用階段了:
由於常規操作都類似,我們建立了一個抽象類:
然後建立一個具體針對User操作的一個類:
萬事大吉,所欠的事情就是調用UerBean中定義的操作進行我們實際所要針對User所做的事情了。我們寫一個簡單的
測試:
哦,好簡潔的代碼。這個測試在執行以後,你查看一下數據庫中的users表,你就會發現,我們真的add一個user了,其它的
操作,我們就略了。
下一篇幅我們介紹如何在web環境下使用我們以上編寫的程序。
二、打開eclipse,建立一個用戶庫,命名爲:hibernate3.2,導入剛解壓的hibernate目錄下的hibernate3.jar
並\lib目錄下的所有jar文件。在Builder path的source and output fold中選擇Folder,並默認給出的文件夾名。
在as JRE library use中選擇JRE_LIB variable。
三、新建一個java工程。在其屬性的Java Build Path中引入剛建立的hibernate3.2用戶庫並mysql的java驅動(
視你所用的數據庫而定,在這我用的是mysql數據庫)。
四、在src中建立一個包,設爲px.malijun,並在其中建立以下幾個Java Class:
User.java
- package px.malijun;
- public class User {
- private int id;
- private String name;
- private String password;
- private String email;
- public String getEmail() {
- return email;
- }
- public void setEmail(String email) {
- this.email = email;
- }
- public String getName() {
- return name;
- }
- public void setName(String name) {
- this.name = name;
- }
- public String getPassword() {
- return password;
- }
- public void setPassword(String password) {
- this.password = password;
- }
- public int getId() {
- return id;
- }
- public void setId(int id) {
- this.id = id;
- }
- }
建立相應的xml映射文件:
User.hbm.xml
- <?xml version="1.0" encoding='utf-8'?>
- <!DOCTYPE hibernate-mapping PUBLIC
- "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
- "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
- <hibernate-mapping>
- <class name="px.malijun.User" table="users">
- <id name="id">
- <generator class="identity"/>
- </id>
- <property name="name"/>
- <property name="password"/>
- <property name="email"/>
- </class>
- </hibernate-mapping>
在數據庫中建立一個myproject(按你的意思定名)數據庫,在其中建立一個users表(向RoR學習):
- CREATE TABLE `users` (
- `id` int(11) NOT NULL auto_increment,
- `name` varchar(255) default NULL,
- `password` varchar(255) default NULL,
- `email` varchar(255) default NULL,
- PRIMARY KEY (`id`)
- )
注:我是用phpmyadmin對mysql數據庫進行管理的,在建立的時候我特意爲其選擇了utf-8編碼。
在src的根目錄下(以上的user.hbm.xml映射文件與User.java在同一目錄下)建立hibernate的配置文件:
hibernate.cfg.xml
- <?xml version="1.0" encoding="utf-8"?>
- <!DOCTYPE hibernate-configuration PUBLIC
- "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
- "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
- <hibernate-configuration>
- <session-factory>
- <!-- 顯示實際操作數據庫時的SQL -->
- <property name="show_sql">true</property>
- <!-- SQL 方言,這邊設定的是MySQL -->
- <property name="dialect">org.hibernate.dialect.MySQLDialect</property>
- <!-- JDBC 驅動程序 -->
- <property name="connection.driver_class">com.mysql.jdbc.Driver</property>
- <!-- JDBC URL 注意這邊我設定的所使用的編碼 -->
- <property name="connection.url">jdbc:mysql://localhost:3306/myproject?useUnicode=true&characterEncoding=utf8</property>
- <!-- 數據庫使用者 -->
- <property name="connection.username">root</property>
- <!-- 數據庫密碼 -->
- <property name="connection.password"></property>
- <!-- 以下設置對象與數據庫表格映像文件 -->
- <mapping resource="px/malijun/User.hbm.xml"/>
- </session-factory>
- </hibernate-configuration>
ok 了,下面我們就進入我們的實際使用階段了:
由於常規操作都類似,我們建立了一個抽象類:
HibernateBase.java
- package px.malijun;
- import org.hibernate.*;
- import org.hibernate.cfg.*;
- import java.util.*;
- import java.io.IOException;
- import java.io.PrintWriter;
- public abstract class HibernateBase
- {
- protected SessionFactory sessionFactory;//會話工廠,用於創建會話
- protected Session session;//hibernate會話
- protected Transaction transaction; //hiberante事務
- public HibernateBase()throws HibernateException
- {
- this.initHibernate();
- }
- // 幫助方法
- protected void initHibernate()
- throws HibernateException {
- // 裝載配置,構造SessionFactory對象
- sessionFactory = new Configuration().configure().buildSessionFactory();
- }
- /**
- *開始一個hibernate事務
- */
- protected void beginTransaction()
- throws HibernateException {
- session = sessionFactory.openSession();
- transaction = session.beginTransaction();
- }
- /**
- *結束一個hibernate事務。
- */
- protected void endTransaction(boolean commit)
- throws HibernateException {
- if (commit) {
- transaction.commit();
- } else {
- //如果是隻讀的操作,不需要commit這個事務。
- transaction.rollback();
- }
- session.close();
- }
- }
然後建立一個具體針對User操作的一個類:
UserBean.java
- package px.malijun;
- import org.hibernate.*;
- import org.hibernate.cfg.*;
- import java.util.*;
- /**
- * 和course相關的業務邏輯
- */
- public class UserBean extends HibernateBase {
- public UserBean() throws HibernateException {
- super();
- }
- /**
- * 增加一個Course
- */
- public void addUser(User user) throws HibernateException {
- beginTransaction();
- session.save(user);
- endTransaction(true);
- }
- /**
- * 查詢系統中所有的Course,返回的是包含有Course持久對象的Iterator。
- */
- public Iterator getAllUsers() throws HibernateException {
- String queryString = "select users from User as user";
- beginTransaction();
- Query query = session.createQuery(queryString);
- Iterator it = query.iterate();
- return it;
- }
- /**
- * 刪除給定ID的course
- */
- public void deleteUser(String id) throws HibernateException {
- beginTransaction();
- User user = (User) session.load(User.class, id);
- session.delete(user);
- endTransaction(true);
- }
- /**
- * 按course的名字進行模糊查找,返回的是包含有Course持久對象的Iterator。
- */
- public Iterator getSomeUser(String name) throws HibernateException {
- String queryString = "select u from User as u where u.name like :name";
- beginTransaction();
- Query query = session.createQuery(queryString);
- query.setString("name", "%" + name + "%");
- Iterator it = query.iterate();
- return it;
- }
- }
萬事大吉,所欠的事情就是調用UerBean中定義的操作進行我們實際所要針對User所做的事情了。我們寫一個簡單的
測試:
Test.java
- package px.malijun;
- public class Test {
- /**
- * @param args
- */
- public static void main(String[] args) {
- // TODO Auto-generated method stub
- UserBean ub=new UserBean();
- User user = new User();
- user.setName("你好,世界!");
- user.setPassword("123456");
- user.setEmail("[email protected]");
- ub.addUser(user);
- }
- }
哦,好簡潔的代碼。這個測試在執行以後,你查看一下數據庫中的users表,你就會發現,我們真的add一個user了,其它的
操作,我們就略了。
下一篇幅我們介紹如何在web環境下使用我們以上編寫的程序。