八步详解Hibernate的搭建及使用

开发 后端
本文通过了八个步骤以及一些实例添加用户来介绍Hibernate的搭建和使用,真切的介绍了hibernate的基本用法,其中好多优点等待我们自己去发现,比如hibernate中的缓存机制,映射方案。

上篇博客已经把Hibernate概念和其中的核心接口介绍,下面举个实例添加用户来介绍Hibernate如何使用。

1.创建普通的java项目。

因为Hibernate是一个轻量级的框架,不像servlet,还必须需要tomcat的支持,Hibernate只要jdk支持即可。

2.引入jar包。

可以在项目中直接引入jar包,在:项目--->属性--->然后如下图:

另一种办法就是引入库,相当于一个文件夹,把所有的jar包放到自己新建的文件夹中。在:窗体-->选项-->然后如下图:

3.提供Hibernate的配置文件。hibernate.cfg.xml文件。完成相应的配置。

  1. <hibernate-configuration>  
  2.  
  3. <session-factory>  
  4.  
  5. <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>  
  6.  
  7. <property name="hibernate.connection.url">jdbc:mysql://localhost:3306/hibernate_first</property>  
  8.  
  9. <property name="hibernate.connection.username">root</property>  
  10.  
  11. <property name="hibernate.connection.password">bjpowernode</property>  
  12.  
  13. <property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>  
  14.  
  15. </session-factory>  
  16.  
  17. </hibernate-configuration>  

在这里连接mysql数据库,解释一下上面的标签。按照顺序来依次解释:第一个是连接mySql的驱动;第二个是连接的url;url后面的hibernate_first是数据库名字;第三个是和第四个分别是用户名和密码。第五个是方言。因为 hibernate对数据库封装,对不同的数据库翻译成不同的形式,比如drp中的分页,若是使用oracle数据库,则翻译成sql语句三层嵌套。若是使用mySql数据库,则翻译成limit语句。

4.建立实体User类:

  1. package com.bjpowernode.hibernate;  
  2.  
  3. import java.util.Date;  
  4.  
  5. public class User {  
  6.  
  7.     private String id;  
  8.       
  9.     private String name;  
  10.       
  11.     private String password;  
  12.       
  13.     private Date createTime;  
  14.       
  15.     private Date expireTime;  
  16.  
  17.     public String getId() {  
  18.         return id;  
  19.     }  
  20.  
  21.     public void setId(String id) {  
  22.         this.id = id;  
  23.     }  
  24.  
  25.     public String getName() {  
  26.         return name;  
  27.     }  
  28.  
  29.     public void setName(String name) {  
  30.         this.name = name;  
  31.     }  
  32.  
  33.     public String getPassword() {  
  34.         return password;  
  35.     }  
  36.  
  37.     public void setPassword(String password) {  
  38.         this.password = password;  
  39.     }  
  40.  
  41.     public Date getCreateTime() {  
  42.         return createTime;  
  43.     }  
  44.  
  45.     public void setCreateTime(Date createTime) {  
  46.         this.createTime = createTime;  
  47.     }  
  48.  
  49.     public Date getExpireTime() {  
  50.         return expireTime;  
  51.     }  
  52.  
  53.     public void setExpireTime(Date expireTime) {  
  54.         this.expireTime = expireTime;  
  55.     }  
  56. }  

5.建立User.hbm.xml,此文件用来完成对象与数据库表的字段的映射。也就是实体类的那些字段需要映射到数据库表中呢。

  1. <?xml version="1.0"?>  
  2. <!DOCTYPE hibernate-mapping PUBLIC   
  3.     "-//Hibernate/Hibernate Mapping DTD 3.0//EN" 
  4.     "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">  
  5. <hibernate-mapping>  
  6.     <class name="com.bjpowernode.hibernate.User">  
  7.         <id name="id">  
  8.             <generator class="uuid"/>  
  9.         </id>  
  10.         <property name="name"/>  
  11.         <property name="password"/>  
  12.         <property name="createTime"/>  
  13.         <property name="expireTime"/>  
  14.     </class>  
  15. </hibernate-mapping> 

6.我们也映射完毕了,但是hibernate怎么知道我们映射完了呢,以及如何映射的呢?这就需要我们把我们自己的映射文件告诉hibernate,即:在hibernate.cfg.xml配置我们的映射文件。

  1. <mapping resource="com/bjpowernode/hibernate/User.hbm.xml"/> 

7.生成数据库表。大家也看到了我们上述还没有新建数据表呢,在第三步我们只是新建了数据库而已。按照我们普通的做法,我们应该新建数据表啊,否则实体存放何处啊。这个别急,数据库表这个肯定是需要有的,这个毋庸置疑,但是这个可不像我们原来需要自己亲自动手建立哦,现在hibernate需要帮我们实现哦,如何实现嗯,hibernate会根据配置文件hibernate.cfg.xml和我们的映射文件User.hbm.xml会自动给我们生成相应的表,并且这个表的名字也给我们取好:默认是User。那如何生成表呢?

  1. //默认读取hibernate.cfg.xml文件  
  2.     Configuration cfg = new Configuration().configure();  
  3.       
  4.     SchemaExport export = new SchemaExport(cfg);  
  5.     export.create(truetrue); 

 8.那我们就开始进行操作啦,我们添加一个用户对象,看看hibernate是如何添加的呢?跟我们以前的做法有什么不同呢?

  1. public class Client {  
  2.  
  3.     public static void main(String[] args) {  
  4.           
  5.         //读取hibernate.cfg.xml文件  
  6.         Configuration cfg = new Configuration().configure();  
  7.           
  8.         //建立SessionFactory  
  9.         SessionFactory factory = cfg.buildSessionFactory();  
  10.           
  11.         //取得session  
  12.         Session session = null;  
  13.         try {  
  14.             session = factory.openSession();  
  15.             //开启事务  
  16.             session.beginTransaction();  
  17.             User user = new User();  
  18.             user.setName("张三");  
  19.             user.setPassword("123");  
  20.             user.setCreateTime(new Date());  
  21.             user.setExpireTime(new Date());  
  22.               
  23.             //保存User对象  
  24.             session.save(user);  
  25.               
  26.             //提交事务  
  27.             session.getTransaction().commit();  
  28.         }catch(Exception e) {  
  29.             e.printStackTrace();  
  30.             //回滚事务  
  31.             session.getTransaction().rollback();  
  32.         }finally {  
  33.             if (session != null) {  
  34.                 if (session.isOpen()) {  
  35.                     //关闭session  
  36.                     session.close();  
  37.                 }  
  38.             }  
  39.         }  
  40.     }  

第八步,我们可以看到,没有我们熟悉的insert into表的sql语句了,那怎么添加进去的呢,到底添加了没?让我真实滴告诉你,确实添加进去了,不信的,可以自己尝试哦,这也是hibernate的优点,对jdbc封装的彻底,减少了我们对数据的操作时间哈。

这篇博客就是真切滴介绍了hibernate的基本用法,其中好多优点等待我们自己去发现哦,比如hibernate中的缓存机制,映射方案哦。

 

原文链接:http://blog.csdn.net/llhhyy1989/article/details/7299619

【编辑推荐】

  1. 为什么用Spring来管理Hibernate?
  2. Java并行编程:从并行任务集获取反馈
  3. Java反射机制初探
  4. 不再纠结Java中的String类
  5. Java中常见IO的读写效率对比
责任编辑:林师授 来源: llhhyy1989的博客
相关推荐

2023-09-26 01:03:36

Pandas数据数据集

2010-08-29 20:56:02

路由器DHCP配置

2010-10-22 11:31:53

SQL Server自

2009-10-21 15:03:50

VB入门教程

2015-04-09 14:58:45

OpenStackDocker私有云搭建

2010-06-02 18:38:08

搭建SVN服务器

2009-08-26 16:56:49

Oracle访问Syb

2023-05-19 15:51:36

数据治理工具

2010-04-09 11:21:37

Linux下配置VSf

2017-09-20 07:09:23

网线双绞线电缆

2010-07-02 14:26:55

Visio画UML用例

2009-02-24 09:56:41

DBA职业生涯求职

2011-07-12 22:21:35

打印机技巧

2011-04-28 10:20:22

打印机

2011-04-25 09:24:50

打印机

2009-02-24 20:45:53

软考信息系统集成项目管理工作

2014-09-18 09:42:15

2018-04-23 14:23:12

2009-09-23 16:30:01

Hibernate f

2009-09-24 17:24:20

Hibernate S
点赞
收藏

51CTO技术栈公众号