程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> JAVA編程 >> 關於JAVA >> Java的Hibernate框架聯合MySQL的入門進修教程

Java的Hibernate框架聯合MySQL的入門進修教程

編輯:關於JAVA

Java的Hibernate框架聯合MySQL的入門進修教程。本站提示廣大學習愛好者:(Java的Hibernate框架聯合MySQL的入門進修教程)文章只能為提供參考,不一定能成為您想要的結果。以下是Java的Hibernate框架聯合MySQL的入門進修教程正文


零、關於Hibernate
Hibernate是蟄伏的意思,它是指植物的蟄伏,然則本文評論辯論的Hibernate卻與蟄伏毫有關系,而是接上去要評論辯論的SSH2框架中的一員。Hibernate是一個開源的項目,它是一個對象關系模子的框架,而且對JDBC停止了異常輕量級的封裝,法式員在開辟時可使用對象編程思想停止開辟。
下載地址:http://hibernate.org/orm/downloads/
Note:輕量級和分量級的差別,輕量級的框架包較小,而且應用較簡略,並且測試輕易,開辟效力高;分量級框架則包較年夜,外部封裝的營業進程較龐雜,測試艱苦,如Struts。

對象關系模子:

 Hibernate完成了對象--關系模子的映照,在編程時法式員可以或許直接應用對象模子對數據庫停止操作,它對JDBC停止了輕量級的封裝,別的還封裝了對數據庫操作的SQL語句,應用簡略。固然它有許多長處,然則應用數據庫特征的語句,將很難調優,如:存儲進程等就比擬艱苦。
 Hibernate優缺陷:
(1)長處
A、進步臨盆力;
B、使開辟加倍對象化(阻抗不婚配);
C、可移植性;
D、沒有侵入性,支撐通明耐久化。
(2)缺陷
A、應用數據庫特征的語句,將很難調優;
B、對年夜批量數據更新存在成績;
C、體系中存在年夜量的統計查詢功效。


2、Hibernate實例
上文對Hibernate做了一些初步的解讀,有了實際固然更要有理論,沒有應用過Hibernate是不理解它的方便的,這正如一個愛好飲酒的人第一次品味到茅台一樣,應用後能力更深入的懂得。
上面的實例采取了MySQL數據庫,在MySQL中創立了一個名為Hibernate_first的數據庫,並經由過程Hibernate的映照文件采取對象化編程的辦法創立了一個User表,並向User表中添加信息。
詳細步調:
(1)創立一個通俗的Java Application;
(2)添加Hibernate的jar包,添加jar包時須要將Hibernate.jar、Hibernate援用的第三方jar包和Hibernate和mysql銜接的jar包一同引入個中;
(3)添加數據庫銜接設置裝備擺設文件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> 
    <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property> 
    <property name="hibernate.connection.url">jdbc:mysql://localhost:3306/hibernate_first</property> 
    <property name="hibernate.connection.username">root</property> 
    <property name="hibernate.connection.password">ab12</property> 
    <!-- dialect:方言,封裝的底層API,相似於Runtime,將數據庫轉換為設置裝備擺設中的響應的說話 --> 
    <property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property> 
     
    <!-- 設置數據顯示對數據庫的操作 --> 
    <property name="hibernate.show_sql">true</property> 
     
    <property name="hibernate.format_sql">true</property> 
    <mapping resource="com/hibernate/User.hbm.xml"/> 
  </session-factory> 
</hibernate-configuration> 

(4)樹立實體類稱號為User.java

package com.hibernate; 
 
import java.util.Date; 
 
public class User { 
  private String id; 
  public String getId() { 
    return id; 
  } 
  public void setId(String id) { 
    this.id = id; 
  } 
  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 Date getCreateTime() { 
    return createTime; 
  } 
  public void setCreateTime(Date createTime) { 
    this.createTime = createTime; 
  } 
  public Date getExpireTime() { 
    return expireTime; 
  } 
  public void setExpireTime(Date expireTime) { 
    this.expireTime = expireTime; 
  } 
  private String name; 
  private String password; 
  private Date createTime; 
  private Date expireTime; 
} 

(5)創立User實體類的映照文件User.hbm.xml,完成實體類的映照,並將該文件參加到Hibernate.cfg.xml文件中。

<?xml version="1.0"?> 
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" 
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> 
<!-- Generated 2014-4-30 15:39:33 by Hibernate Tools 3.4.0.CR1 --> 
<hibernate-mapping> 
  <class name="com.hibernate.User"> 
    <id name="id"> 
      <generator class="uuid"/> 
    </id> 
    <property name="name"/> 
    <property name="password"/> 
    <property name="createTime"/> 
    <property name="expireTime"/> 
  </class> 
</hibernate-mapping> 

(6)編寫ExportDB.java,將映照文件轉化為響應的DDL。

package com.hibernate; 
 
import org.hibernate.cfg.Configuration; 
import org.hibernate.tool.hbm2ddl.SchemaExport; 
public class ExportDB { 
  public static void main(String[] args){ 
    //起首聲明獲得設置裝備擺設文件 
    //默許讀取Hibernate.cfg.xml文件 
    Configuration cfg=new Configuration().configure();  
     
    //將讀取到的xml文件導出到ddl 
    SchemaExport export=new SchemaExport(cfg); 
    export.create(true, true); 
  } 
} 

運轉ExportDB類便可完成數據庫表的創立任務,在cmd中檢查詳細操作後的視圖以下:

下面的例子只是完成了銜接數據庫及在數據庫中創立表的操作,創立完表後要向表中添加數據,樹立客戶端類Client,向User表中添加新的用戶信息,詳細代碼以下:

package com.hibernate; 
 
import java.util.Date; 
 
import org.hibernate.Session; 
import org.hibernate.SessionFactory; 
import org.hibernate.cfg.Configuration; 
 
public class Client { 
  public static void main(String[] args){ 
     
    //讀取hibernate.cfg.xml文件 
    Configuration cfg=new Configuration().configure(); 
     
    //創立sessionfactory,相當於數據庫鏡像,sessionfactory由於是鏡像所以就一份,最好創立一次 
    //平日是線程平安的。 
    SessionFactory factory=cfg.buildSessionFactory(); 
     
    //取的session 
    Session session=null; 
     
    try{ 
      session=factory.openSession(); 
      //開啟事務 
      session.beginTransaction(); 
      User user=new User(); 
      user.setName("張三"); 
      user.setPassword("123"); 
      user.setCreateTime(new Date()); 
       
      //保留User對象 
      session.save(user); 
       
      //提交事務 
      session.getTransaction().commit(); 
    }catch(Exception e){ 
      e.printStackTrace();//打印毛病信息 
      //回滾事務 
      session.getTransaction().rollback(); 
    }finally{ 
      if(session != null){ 
        if(session.isOpen()){ 
          //封閉session 
          session.close(); 
        } 
      } 
    } 
  } 
} 

在mysql中檢查添加的信息顯示以下圖:

下面操作的信息曾經寫入到數據庫中,數據庫中的數據在save以後在數據庫中生成了響應的行,然則此時還沒有真實的保留,而是在數據庫中曾經有絕對應的行數據,當應用session的事務提交完成後才把數據提交到了數據庫中。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved