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的事務提交完成後才把數據提交到了數據庫中。