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