国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Java > 正文

Java的Hibernate框架結合MySQL的入門學習教程

2019-11-26 14:05:53
字體:
來源:轉載
供稿:網友

零、關于Hibernate
Hibernate是冬眠的意思,它是指動物的冬眠,但是本文討論的Hibernate卻與冬眠毫無關系,而是接下來要討論的SSH2框架中的一員。Hibernate是一個開源的項目,它是一個對象關系模型的框架,并且對JDBC進行了非常輕量級的封裝,程序員在開發時可以使用對象編程思維進行開發。
下載地址:http://hibernate.org/orm/downloads/
Note:輕量級和重量級的區別,輕量級的框架包較小,并且使用較簡單,而且測試容易,開發效率高;重量級框架則包較大,內部封裝的業務過程較復雜,測試困難,如Struts。

201676182320036.png (558×411)

對象關系模型:

201676182344905.png (620×398)

 Hibernate實現了對象--關系模型的映射,在編程時程序員能夠直接使用對象模型對數據庫進行操作,它對JDBC進行了輕量級的封裝,另外還封裝了對數據庫操作的SQL語句,使用簡單。雖然它有很多優點,但是使用數據庫特性的語句,將很難調優,如:存儲過程等就比較困難。
 Hibernate優缺點:
(1)優點
A、提高生產力;
B、使開發更加對象化(阻抗不匹配);
C、可移植性;
D、沒有侵入性,支持透明持久化。
(2)缺點
A、使用數據庫特性的語句,將很難調優;
B、對大批量數據更新存在問題;
C、系統中存在大量的統計查詢功能。


二、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中查看具體操作后的視圖如下:

201676182756720.png (508×189)

上面的例子只是完成了連接數據庫及在數據庫中創建表的操作,創建完表后要向表中添加數據,建立客戶端類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中查看添加的信息顯示如下圖:

201676182824926.png (730×203)

上面操作的信息已經寫入到數據庫中,數據庫中的數據在save之后在數據庫中生成了相應的行,但是此時還沒有真正的保存,而是在數據庫中已經有相對應的行數據,當使用session的事務提交完成后才把數據提交到了數據庫中。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 崇文区| 遂平县| 武隆县| 神农架林区| 玉屏| 鸡泽县| 桐城市| 渝中区| 马山县| 札达县| 时尚| 上犹县| 崇阳县| 邵阳市| 湖北省| 漠河县| 贞丰县| 安溪县| 晋城| 子长县| 茂名市| 平利县| 锦州市| 安乡县| 安西县| 墨竹工卡县| 宁河县| 龙山县| 永福县| 南汇区| 永吉县| 绥化市| 靖远县| 神木县| 米易县| 浦城县| 龙胜| 苍南县| 遂宁市| 馆陶县| 海城市|