八步詳解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è)可不像我們?cè)瓉硇枰约河H自動(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
【編輯推薦】