一個簡單的hibernate實例(之一)

一、下載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:


User.java
 
  1. package px.malijun;  
  2.   
  3. public class User {  
  4.     private int id;  
  5.     private String name;  
  6.     private String password;  
  7.     private String email;  
  8.     public String getEmail() {  
  9.         return email;  
  10.     }  
  11.     public void setEmail(String email) {  
  12.         this.email = email;  
  13.     }  
  14.     public String getName() {  
  15.         return name;  
  16.     }  
  17.     public void setName(String name) {  
  18.         this.name = name;  
  19.     }  
  20.     public String getPassword() {  
  21.         return password;  
  22.     }  
  23.     public void setPassword(String password) {  
  24.         this.password = password;  
  25.     }  
  26.     public int getId() {  
  27.         return id;  
  28.     }  
  29.     public void setId(int id) {  
  30.         this.id = id;  
  31.     }  
  32.  
  33. }  


建立相應的xml映射文件:

User.hbm.xml
 
  1. <?xml version="1.0" encoding='utf-8'?>  
  2. <!DOCTYPE hibernate-mapping PUBLIC  
  3.         "-//Hibernate/Hibernate Mapping DTD 3.0//EN"  
  4.         "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">  
  5.   
  6. <hibernate-mapping>  
  7.     <class name="px.malijun.User" table="users">  
  8.     <id name="id">  
  9.      <generator class="identity"/>  
  10.      </id>  
  11.         <property name="name"/>  
  12.         <property name="password"/>  
  13.         <property name="email"/>  
  14.     </class>  
  15. </hibernate-mapping>  


在數據庫中建立一個myproject(按你的意思定名)數據庫,在其中建立一個users表(向RoR學習):
 
  1. CREATE TABLE `users` (  
  2.   `id` int(11) NOT NULL auto_increment,  
  3.   `namevarchar(255) default NULL,  
  4.   `passwordvarchar(255) default NULL,  
  5.   `email` varchar(255) default NULL,  
  6.   PRIMARY KEY  (`id`)  



注:我是用phpmyadmin對mysql數據庫進行管理的,在建立的時候我特意爲其選擇了utf-8編碼。


在src的根目錄下(以上的user.hbm.xml映射文件與User.java在同一目錄下)建立hibernate的配置文件:

hibernate.cfg.xml
 
  1. <?xml version="1.0" encoding="utf-8"?>  
  2.   
  3. <!DOCTYPE hibernate-configuration PUBLIC  
  4.   
  5. "-//Hibernate/Hibernate Configuration DTD 3.0//EN"  
  6.   
  7. "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">  
  8.   
  9. <hibernate-configuration>  
  10.   
  11.     <session-factory>  
  12.       
  13.         <!-- 顯示實際操作數據庫時的SQL -->  
  14.           
  15.         <property name="show_sql">true</property>  
  16.           
  17.         <!-- SQL 方言,這邊設定的是MySQL -->  
  18.           
  19.         <property name="dialect">org.hibernate.dialect.MySQLDialect</property>  
  20.           
  21.         <!-- JDBC 驅動程序 -->  
  22.           
  23.         <property name="connection.driver_class">com.mysql.jdbc.Driver</property>  
  24.           
  25.         <!-- JDBC URL 注意這邊我設定的所使用的編碼 -->  
  26.           
  27.         <property name="connection.url">jdbc:mysql://localhost:3306/myproject?useUnicode=true&amp;characterEncoding=utf8</property>  
  28.           
  29.         <!-- 數據庫使用者 -->  
  30.           
  31.         <property name="connection.username">root</property>  
  32.           
  33.         <!-- 數據庫密碼 -->  
  34.           
  35.         <property name="connection.password"></property>  
  36.           
  37.         <!-- 以下設置對象與數據庫表格映像文件 -->  
  38.         <mapping resource="px/malijun/User.hbm.xml"/>  
  39.       
  40.     </session-factory>  
  41.   
  42. </hibernate-configuration>
  43.   


ok 了,下面我們就進入我們的實際使用階段了:


由於常規操作都類似,我們建立了一個抽象類:

HibernateBase.java
 
  1. package px.malijun;  
  2.   
  3. import org.hibernate.*;  
  4. import org.hibernate.cfg.*;  
  5. import java.util.*;  
  6. import java.io.IOException;  
  7. import java.io.PrintWriter;  
  8.        
  9.      public abstract class HibernateBase   
  10.      {  
  11.      protected SessionFactory sessionFactory;//會話工廠,用於創建會話  
  12.      protected Session session;//hibernate會話  
  13.      protected Transaction transaction; //hiberante事務  
  14.        
  15.      public HibernateBase()throws HibernateException  
  16.      {  
  17.      this.initHibernate();  
  18.      }  
  19.      // 幫助方法  
  20.      protected void initHibernate()  
  21.      throws HibernateException {  
  22.        
  23.      // 裝載配置,構造SessionFactory對象  
  24.      sessionFactory = new Configuration().configure().buildSessionFactory();  
  25.      }  
  26.        
  27.      /** 
  28.      *開始一個hibernate事務 
  29.      */  
  30.      protected void beginTransaction()  
  31.      throws HibernateException {  
  32.        
  33.      session = sessionFactory.openSession();  
  34.      transaction = session.beginTransaction();  
  35.      }  
  36.        
  37.      /** 
  38.      *結束一個hibernate事務。 
  39.      */  
  40.      protected void endTransaction(boolean commit)  
  41.      throws HibernateException {  
  42.        
  43.      if (commit) {  
  44.      transaction.commit();  
  45.      } else {  
  46.      //如果是隻讀的操作,不需要commit這個事務。  
  47.      transaction.rollback();  
  48.      }  
  49.      session.close();  
  50.      }  
  51. }  


然後建立一個具體針對User操作的一個類:
UserBean.java
 
  1. package px.malijun;  
  2.   
  3. import org.hibernate.*;  
  4. import org.hibernate.cfg.*;  
  5. import java.util.*;  
  6.   
  7. /** 
  8.  * 和course相關的業務邏輯 
  9.  */  
  10. public class UserBean extends HibernateBase {  
  11.     public UserBean() throws HibernateException {  
  12.         super();  
  13.     }  
  14.   
  15.     /** 
  16.      * 增加一個Course 
  17.      */  
  18.     public void addUser(User user) throws HibernateException {  
  19.         beginTransaction();  
  20.         session.save(user);  
  21.         endTransaction(true);  
  22.     }  
  23.   
  24.     /** 
  25.      * 查詢系統中所有的Course,返回的是包含有Course持久對象的Iterator。 
  26.      */  
  27.     public Iterator getAllUsers() throws HibernateException {  
  28.         String queryString = "select users from User as user";  
  29.         beginTransaction();  
  30.         Query query = session.createQuery(queryString);  
  31.         Iterator it = query.iterate();  
  32.         return it;  
  33.     }  
  34.   
  35.     /** 
  36.      * 刪除給定ID的course 
  37.      */  
  38.     public void deleteUser(String id) throws HibernateException {  
  39.         beginTransaction();  
  40.         User user = (User) session.load(User.class, id);  
  41.         session.delete(user);  
  42.         endTransaction(true);  
  43.     }  
  44.   
  45.     /** 
  46.      * 按course的名字進行模糊查找,返回的是包含有Course持久對象的Iterator。 
  47.      */  
  48.     public Iterator getSomeUser(String name) throws HibernateException {  
  49.         String queryString = "select u from User as u where u.name like :name";  
  50.         beginTransaction();  
  51.         Query query = session.createQuery(queryString);  
  52.         query.setString("name""%" + name + "%");  
  53.         Iterator it = query.iterate();  
  54.         return it;  
  55.     }  
  56. }  

萬事大吉,所欠的事情就是調用UerBean中定義的操作進行我們實際所要針對User所做的事情了。我們寫一個簡單的
測試:

Test.java
 
  1. package px.malijun;  
  2.   
  3. public class Test {  
  4.   
  5.     /** 
  6.      * @param args 
  7.      */  
  8.     public static void main(String[] args) {  
  9.         // TODO Auto-generated method stub  
  10.         UserBean ub=new UserBean();  
  11.         User user = new User();  
  12.         user.setName("你好,世界!");  
  13.         user.setPassword("123456");  
  14.         user.setEmail("[email protected]");  
  15.         ub.addUser(user);  
  16.   
  17.     }  
  18.   
  19. }  


哦,好簡潔的代碼。這個測試在執行以後,你查看一下數據庫中的users表,你就會發現,我們真的add一個user了,其它的
操作,我們就略了。

下一篇幅我們介紹如何在web環境下使用我們以上編寫的程序。
發佈了10 篇原創文章 · 獲贊 1 · 訪問量 3785
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章