新聞中心
上篇博客已經(jīng)把Hibernate概念和其中的核心接口介紹,下面舉個(gè)實(shí)例添加用戶(hù)來(lái)介紹Hibernate如何使用。

1.創(chuàng)建普通的java項(xiàng)目。
因?yàn)镠ibernate是一個(gè)輕量級(jí)的框架,不像servlet,還必須需要tomcat的支持,Hibernate只要jdk支持即可。
2.引入jar包。
可以在項(xiàng)目中直接引入jar包,在:項(xiàng)目--->屬性--->然后如下圖:
另一種辦法就是引入庫(kù),相當(dāng)于一個(gè)文件夾,把所有的jar包放到自己新建的文件夾中。在:窗體-->選項(xiàng)-->然后如下圖:
3.提供Hibernate的配置文件。hibernate.cfg.xml文件。完成相應(yīng)的配置。
com.mysql.jdbc.Driver jdbc:mysql://localhost:3306/hibernate_first root bjpowernode org.hibernate.dialect.MySQLDialect
在這里連接mysql數(shù)據(jù)庫(kù),解釋一下上面的標(biāo)簽。按照順序來(lái)依次解釋?zhuān)旱谝粋€(gè)是連接mySql的驅(qū)動(dòng);第二個(gè)是連接的url;url后面的hibernate_first是數(shù)據(jù)庫(kù)名字;第三個(gè)是和第四個(gè)分別是用戶(hù)名和密碼。第五個(gè)是方言。因?yàn)?hibernate對(duì)數(shù)據(jù)庫(kù)封裝,對(duì)不同的數(shù)據(jù)庫(kù)翻譯成不同的形式,比如drp中的分頁(yè),若是使用oracle數(shù)據(jù)庫(kù),則翻譯成sql語(yǔ)句三層嵌套。若是使用mySql數(shù)據(jù)庫(kù),則翻譯成limit語(yǔ)句。
4.建立實(shí)體User類(lèi):
- 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,此文件用來(lái)完成對(duì)象與數(shù)據(jù)庫(kù)表的字段的映射。也就是實(shí)體類(lèi)的那些字段需要映射到數(shù)據(jù)庫(kù)表中呢。
- "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
- "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
6.我們也映射完畢了,但是hibernate怎么知道我們映射完了呢,以及如何映射的呢?這就需要我們把我們自己的映射文件告訴hibernate,即:在hibernate.cfg.xml配置我們的映射文件。
7.生成數(shù)據(jù)庫(kù)表。大家也看到了我們上述還沒(méi)有新建數(shù)據(jù)表呢,在第三步我們只是新建了數(shù)據(jù)庫(kù)而已。按照我們普通的做法,我們應(yīng)該新建數(shù)據(jù)表啊,否則實(shí)體存放何處啊。這個(gè)別急,數(shù)據(jù)庫(kù)表這個(gè)肯定是需要有的,這個(gè)毋庸置疑,但是這個(gè)可不像我們?cè)瓉?lái)需要自己親自動(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.那我們就開(kāi)始進(jìn)行操作啦,我們添加一個(gè)用戶(hù)對(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();
- //開(kāi)啟事務(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();
- }
- }
- }
- }
- }
第八步,我們可以看到,沒(méi)有我們熟悉的insert into表的sql語(yǔ)句了,那怎么添加進(jìn)去的呢,到底添加了沒(méi)?讓我真實(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ī)制,映射方案哦。
新聞名稱(chēng):八步詳解Hibernate的搭建及使用
瀏覽路徑:http://m.fisionsoft.com.cn/article/dhgcigg.html


咨詢(xún)
建站咨詢(xún)
