八步詳解Hibernate的搭建及使用
上篇博客已經(jīng)把Hibernate概念和其中的核心接口介紹,下面舉個(gè)實(shí)例添加用戶來介紹Hibernate如何使用。
1.創(chuàng)建普通的java項(xiàng)目。
因?yàn)镠ibernate是一個(gè)輕量級(jí)的框架,不像servlet,還必須需要tomcat的支持,Hibernate只要jdk支持即可。
2.引入jar包。
可以在項(xiàng)目中直接引入jar包,在:項(xiàng)目--->屬性--->然后如下圖:
另一種辦法就是引入庫,相當(dāng)于一個(gè)文件夾,把所有的jar包放到自己新建的文件夾中。在:窗體-->選項(xiàng)-->然后如下圖:
3.提供Hibernate的配置文件。hibernate.cfg.xml文件。完成相應(yīng)的配置。
- <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">bjpowernode</property>
 - <property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
 - </session-factory>
 - </hibernate-configuration>
 
在這里連接mysql數(shù)據(jù)庫,解釋一下上面的標(biāo)簽。按照順序來依次解釋:第一個(gè)是連接mySql的驅(qū)動(dòng);第二個(gè)是連接的url;url后面的hibernate_first是數(shù)據(jù)庫名字;第三個(gè)是和第四個(gè)分別是用戶名和密碼。第五個(gè)是方言。因?yàn)?hibernate對(duì)數(shù)據(jù)庫封裝,對(duì)不同的數(shù)據(jù)庫翻譯成不同的形式,比如drp中的分頁,若是使用oracle數(shù)據(jù)庫,則翻譯成sql語句三層嵌套。若是使用mySql數(shù)據(jù)庫,則翻譯成limit語句。
4.建立實(shí)體User類:
- package com.bjpowernode.hibernate;
 - import java.util.Date;
 - public class User {
 - private String id;
 - private String name;
 - private String password;
 - private Date createTime;
 - private Date expireTime;
 - 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;
 - }
 - }
 
5.建立User.hbm.xml,此文件用來完成對(duì)象與數(shù)據(jù)庫表的字段的映射。也就是實(shí)體類的那些字段需要映射到數(shù)據(jù)庫表中呢。
- <?xml version="1.0"?>
 - <!DOCTYPE hibernate-mapping PUBLIC
 - "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
 - "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
 - <hibernate-mapping>
 - <class name="com.bjpowernode.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.我們也映射完畢了,但是hibernate怎么知道我們映射完了呢,以及如何映射的呢?這就需要我們把我們自己的映射文件告訴hibernate,即:在hibernate.cfg.xml配置我們的映射文件。
- <mapping resource="com/bjpowernode/hibernate/User.hbm.xml"/>
 
7.生成數(shù)據(jù)庫表。大家也看到了我們上述還沒有新建數(shù)據(jù)表呢,在第三步我們只是新建了數(shù)據(jù)庫而已。按照我們普通的做法,我們應(yīng)該新建數(shù)據(jù)表啊,否則實(shí)體存放何處啊。這個(gè)別急,數(shù)據(jù)庫表這個(gè)肯定是需要有的,這個(gè)毋庸置疑,但是這個(gè)可不像我們原來需要自己親自動(dòng)手建立哦,現(xiàn)在hibernate需要幫我們實(shí)現(xiàn)哦,如何實(shí)現(xiàn)嗯,hibernate會(huì)根據(jù)配置文件hibernate.cfg.xml和我們的映射文件User.hbm.xml會(huì)自動(dòng)給我們生成相應(yīng)的表,并且這個(gè)表的名字也給我們?nèi)『茫耗J(rèn)是User。那如何生成表呢?
- //默認(rèn)讀取hibernate.cfg.xml文件
 - Configuration cfg = new Configuration().configure();
 - SchemaExport export = new SchemaExport(cfg);
 - export.create(true, true);
 
8.那我們就開始進(jìn)行操作啦,我們添加一個(gè)用戶對(duì)象,看看hibernate是如何添加的呢?跟我們以前的做法有什么不同呢?
- public class Client {
 - public static void main(String[] args) {
 - //讀取hibernate.cfg.xml文件
 - Configuration cfg = new Configuration().configure();
 - //建立SessionFactory
 - SessionFactory factory = cfg.buildSessionFactory();
 - //取得session
 - Session session = null;
 - try {
 - session = factory.openSession();
 - //開啟事務(wù)
 - session.beginTransaction();
 - User user = new User();
 - user.setName("張三");
 - user.setPassword("123");
 - user.setCreateTime(new Date());
 - user.setExpireTime(new Date());
 - //保存User對(duì)象
 - session.save(user);
 - //提交事務(wù)
 - session.getTransaction().commit();
 - }catch(Exception e) {
 - e.printStackTrace();
 - //回滾事務(wù)
 - session.getTransaction().rollback();
 - }finally {
 - if (session != null) {
 - if (session.isOpen()) {
 - //關(guān)閉session
 - session.close();
 - }
 - }
 - }
 - }
 - }
 
第八步,我們可以看到,沒有我們熟悉的insert into表的sql語句了,那怎么添加進(jìn)去的呢,到底添加了沒?讓我真實(shí)滴告訴你,確實(shí)添加進(jìn)去了,不信的,可以自己嘗試哦,這也是hibernate的優(yōu)點(diǎn),對(duì)jdbc封裝的徹底,減少了我們對(duì)數(shù)據(jù)的操作時(shí)間哈。
這篇博客就是真切滴介紹了hibernate的基本用法,其中好多優(yōu)點(diǎn)等待我們自己去發(fā)現(xiàn)哦,比如hibernate中的緩存機(jī)制,映射方案哦。
原文鏈接:http://blog.csdn.net/llhhyy1989/article/details/7299619
【編輯推薦】















 
 
 



 
 
 
 