浅谈JavaEE中的Hibernate环境的搭建(二)

从今天开始,我们一起来进入有关Hibernate框架的学习,Hibernate框架实际上是基于JDBC的高度封装的框架,所以对比起来Hibernate的运行效率没有JDBC效率高但是Hibernate的开发效率却比JDBC的要高,这也是企业级开发所追求的。所以目前大部分企业开发都不会使用JDBC。欲工善其事,必先利其器,首先我们熟悉下Hibernate环境搭建。

Hibernate环境搭建步骤:

第一步:获取到Hibernate发布包,可以去Hibernate官网上去下载,或者去GitHub直接搜索Hibernate,Hibernate的代码是托管到GitHub

下载地址:https://sourceforge.net/projects/hibernate/files/hibernate3/,官网下载地址:http://in.relation.to/hibernate-orm/.我这里的拿到的发布包是Hibernate3现在更新到4版本了,不管用3还是4都可以,但是一定要统一,不要既用部分3.0的jar包,又使用了4.0的jar这样就会出问题,到后期开发中会出现一系列的问题,建议统一所有jar版本,其实也不用担心,你只需要下载一个完整的Final包,所需的jar里面全都有。下载完Final包后解压后的目录如下图:

Hibernate一共包括了23个jar包,令人眼花缭乱。本文将详细讲解Hibernate每个jar包的作用,便于你在应用中根据自己的需要进行取舍。

  下载Hibernate,例如3.6.1稳定版本,解压缩,可以看到一个hibernate3.jar和lib目录下有22个jar包:

  hibernate3.jar:

  Hibernate的库,没有什么可说的,必须使用的jar包

  cglib-asm.jar:

  CGLIB库,Hibernate用它来实现PO字节码的动态生成,非常核心的库,必须使用的jar包

  dom4j.jar:

  dom4j是一个Java的XML API,类似于jdom,用来读写XML文件的。dom4j是一个非常非常优秀的Java XML API,具有性能优异、功能强大和极端易用使用的特点,同时它也是一个开放源代码的软件,可以在SourceForge上找到它。在IBM developerWorks上面可以找到一篇文章,对主流的Java XML API进行的性能、功能和易用性的评测,dom4j无论在那个方面都是非常出色的。我早在将近一年之前就开始使用dom4j,直到现在。如今你可以看到越来越多的Java软件都在使用dom4j来读写XML,特别值得一提的是连Sun的JAXM也在用dom4j。这是必须使用的jar包,Hibernate用它来读写配置文件。

  odmg.jar:

  ODMG是一个ORM的规范,Hibernate实现了ODMG规范,这是一个核心的库,必须使用的jar包。

  commons-collections.jar:

  Apache Commons包中的一个,包含了一些Apache开发的集合类,功能比java.util.*强大。必须使用的jar包。

  commons-beanutils.jar:

  Apache Commons包中的一个,包含了一些Bean工具类类。必须使用的jar包。

  commons-lang.jar:

  Apache Commons包中的一个,包含了一些数据类型工具类,是java.lang.*的扩展。必须使用的jar包。

  commons-logging.jar:

  Apache Commons包中的一个,包含了日志功能,必须使用的jar包。这个包本身包含了一个Simple Logger,但是功能很弱。在运行的时候它会先在CLASSPATH找log4j,如果有,就使用log4j,如果没有,就找JDK1.4带的java.util.logging,如果也找不到就用Simple Logger。commons-logging.jar的出现是一个历史的的遗留的遗憾,当初Apache极力游说Sun把log4j加入JDK1.4,然而JDK1.4项目小组已经接近发布JDK1.4产品的时间了,因此拒绝了Apache的要求,使用自己的java.util.logging,这个包的功能比log4j差的很远,性能也一般。后来Apache就开发出来了commons-logging.jar用来兼容两个logger。因此用commons-logging.jar写的log程序,底层的Logger是可以切换的,你可以选择log4j,java.util.logging或者它自带的Simple
Logger。不过我仍然强烈建议使用log4j,因为log4j性能很高,log输出信息时间几乎等于System.out,而处理一条log平均只需要5us。你可以在Hibernate的src目录下找到Hibernate已经为你准备好了的log4j的配置文件,你只需要到Apache 网站去下载log4j就可以了。commons-logging.jar也是必须的jar包。

  使用Hibernate必须的jar包就是以上的这几个,剩下的都是可选的。

  ant.jar:

  Ant编译工具的jar包,用来编译Hibernate源代码的。如果你不准备修改和编译Hibernate源代码,那么就没有什么用,可选的jar包

  optional.jar:

  Ant的一个辅助包。

  c3p0.jar:

  C3PO是一个数据库连接池,Hibernate可以配置为使用C3PO连接池。如果你准备用这个连接池,就需要这个jar包。

  proxool.jar:

  也是一个连接池,同上。

  commons-pool.jar, commons-dbcp.jar:

  DBCP数据库连接池,Apache的Jakarta组织开发的,Tomcat4的连接池也是DBCP。

  实际上Hibernate自己也实现了一个非常非常简单的数据库连接池,加上上面3个,你实际上可以在Hibernate上选择4种不同的数据库连接池,选择哪一个看个人的偏好,不过DBCP可能更通用一些。另外强调一点,如果在EJB中使用Hibernate,一定要用App Server的连接池,不要用以上4种连接池,否则容器管理事务不起作用。

  connector.jar:

  JCA 规范,如果你在App Server上把Hibernate配置为Connector的话,就需要这个jar。不过实际上一般App Server肯定会带上这个包,所以实际上是多余的包。

  jaas.jar:

  JAAS是用来进行权限验证的,已经包含在JDK1.4里面了。所以实际上是多余的包。

  jcs.jar:

  如果你准备在Hibernate中使用JCS的话,那么必须包括它,否则就不用。

  JDBC2_0-stdext.jar:

  JDBC2.0的扩展包,一般来说数据库连接池会用上它。不过App Server都会带上,所以也是多余的。

  jta.jar:

  JTA规范,当Hibernate使用JTA的时候需要,不过App Server都会带上,所以也是多余的。

  junit.jar:

  Junit包,当你运行Hibernate自带的测试代码的时候需要,否则就不用。

  xalan.jar, xerces.jar, xml-apis.jar:

  Xerces是XML解析器,Xalan是格式化器,xml-apis实际上是JAXP。一般App Server都会带上,JDK1.4也包含了解析器,不过不是Xerces,是Crimson,效率比较差,不过Hibernate用XML只不过是读取配置文件,性能没什么紧要的,所以也是多余的。

通过上面对Hibernate下的23个jar包作用的简单分析和介绍,相信你应该知道怎么去选择适合你开发的jar吧,但是对于一般新手入门开发Hibernate所必须的jar只有8个

这个8个jar分别是:1、Hibernate3.jar,Hibernate库jar包肯定是必须的  2、在你的解压目录下有个lib目录,lib目录中有四个文件夹,选择require(必需的)文件夹中全部的6个jar,

然后再选择jpa文件夹中的全部的1个jar,总共8个jar包。

第二步:打开Eclipse新建一个Dynamic Web Project,并且在项目的根目录下新建一个dtd文件夹,然后在Final包解压文件夹内有个Hibernate3.jar也即是Hibernate的核心库用解压缩软件将其解压,解压的后到hibernate目录中找到两个以.dtd结尾的文件,将他们复制到我们刚刚建好的dtd文件目录下。实际上这两个文件就是分别配置Hibernate中的核心配置文件,和关系映射文件。

第三步将我们上面选好的8个jar放入到webContent中的WEB-INF/lib目录下,此外我们还需要放入一个连接数据库的驱动包,我这里使用的mysql数据驱动包。记住一定要放到webContent中的WEB-INF/lib目录下,不要自己去建个文件夹然后再Add Bulide path这样在以后的Web开发中会报异常找不到类的异常,也不需要Add bulide Path,因为这是一个动态的Web项目,它会自动加入到路径中。

第四步:配置Hibernate的核心配置文件hibernate.cfg.xml,在项目的src目录下新建一个XML文件,src目录是Hibernate默认加载目录,记住在新建Hibernate配置文件的时候

一定不要自己随意取名字,它只有一个名字hibernate.cfg.xml,不要写错,否则环境是无效的。

然后接着打开dtd目录下的hibernate-configuration-3.0.dtd文件如下:

将选中的代码粘贴到hibernate.cfg.xml中,并且再将选中的URL复制一下

然后按照图上红箭头操作:

确认配置好后如图,并且可以打出Hibernate配置代码提示就说明我们已经关联好了。

最后,我们就可以通过代码在该XML文件配置Hibernate了,但是由于很多配置的代码根本不熟,所以我们需要去Copy文档中的实例,注意这种代码不需要你记住,因为记住它没有多大意义,所以还是看文档吧。文档在哪看呢?在解压后的发布包的文件夹中有个documentation文件夹,然后里面有个manual文件夹,打开该文件夹,里面有个zh_CN的中文API文档,打开zh_CN里面有个html文件夹里面全是一些html格式的文档,找到Hibernate配置那一栏,然后复制<hibernate-configuration>标签内所有的内容,然后将复制的内容拷贝到我们建好的hibernate.cfg.xml中即可。

最终hibernate.cfg.xml配置代码如下:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC
	"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
	"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
<hibernate-configuration>

	<session-factory>

		<!-- Database connection settings -->
		<property name="connection.driver_class">com.mysql.jdbc.Driver</property><!-- 数据库的驱动完整类名 ,根据自己需求替换-->
		<property name="connection.url">jdbc:mysql://127.0.0.1:3306/demo</property><!-- 数据库连接地址 /后跟数据库名,根据自己需求替换-->
		<property name="connection.username">root</property><!-- 用户名根据自己需求替换 -->
		<property name="connection.password">root</property><!-- 密码 根据自己需求替换-->

		<!-- JDBC connection pool (use the built-in) -->
		<property name="connection.pool_size">1</property>

		<!-- SQL dialect -->
		<property name="dialect">org.hibernate.dialect.MySQLDialect</property><!-- 设置相应数据库的方言根据自己需求替换 -->

		<!-- Enable Hibernate's automatic session context management -->
		<property name="current_session_context_class">thread</property>

		<!-- Disable the second-level cache -->
		<property name="cache.provider_class">org.hibernate.cache.NoCacheProvider</property>

		<!-- Echo all executed SQL to stdout -->
		<property name="show_sql">true</property><!--打印sql语句到控制台  -->
		<property name="format_sql">true</property><!--对打印到控制台的sql语句进行格式化  -->
		<!-- Drop and re-create the database schema on startup -->
		<property name="hbm2ddl.auto">update</property><!-- 自动建表 -->

	</session-factory>

</hibernate-configuration>

第五步配置表的映射文件,Hibernate中的映射文件非常重要,可以借助映射文件将我们的Bean类转换成数据库中的一张表,也就是说我们只要把Bean类建好了,写好了映射文件的信息,并把映射文件配置到配置文件中,利用Hibernate的API就可以实现自动创建数据表,这个也是检测我们Hibernate环境是否搭建好的方法之一。

那么我们首先就来建一个Student类(Bean类)对象和一个测试类对象TableTest.并且先建立一个空的名为demo的数据库。

那么接下来就配置映射文件,记住在bean包下新建一个xml文件,文件名字是Student(Bean类的小写),student.hbm.xml,然后打开dtd目录下的hibernate-mapping-3.0.dtd文件,然后打开该文件,复制头部分内容,将这些内容粘贴到student.hbm.xml中。

然后以上选中的URL复制一下,按照如同以上配置

最后只要检测到代码提示就说明已经关联成功了。那么接下来就是怎么去写映射文件了,我在这里就不去找API了,我就给出一个格式,以后基本可以按照这个格式来即可

注意:以后在写映射文件的时候一定要对应Bean类来写,这里为了好看和理解方便,我就把Student(Bean类)和student.hbm.xml映射文件放在一起对应看。

package com.mikyou.bean;

import java.io.Serializable;

public class Student implements Serializable{
	/**
	 *
	 */
	private static final long serialVersionUID = 1L;
	private Long id;
	private String name;
	private int age;
	private String sex;
	public Student(Long id, String name, int age, String sex) {
		super();
		this.id = id;
		this.name = name;
		this.age = age;
		this.sex = sex;
	}
	public Student() {
		// TODO Auto-generated constructor stub
	}
	public Long getId() {
		return id;
	}
	public void setId(Long id) {
		this.id = id;
	}
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name = name;
	}
	public int getAge() {
		return age;
	}
	public void setAge(int age) {
		this.age = age;
	}
	public String getSex() {
		return sex;
	}
	public void setSex(String sex) {
		this.sex = sex;
	}
	public static long getSerialversionuid() {
		return serialVersionUID;
	}
	@Override
	public String toString() {
		return "Student [id=" + id + ", name=" + name + ", age=" + age + ", sex=" + sex + "]";
	}

}
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC
    "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
    "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
    <hibernate-mapping package="com.mikyou.bean"><!-- 这里表示Student,Bean类所在包路径 -->
	<class name="Student" table="demo_student"><!-- 左边的name为类名 对应着  数据库中的表名demo_student -->
		<id name="id" column="id"><!-- id标签表示主键生成即表示Student中的id属性,对应数据库表中的id列,并且该列为该表的主键 -->
			<generator class="increment" /><!-- 这里表示主键生成机制为自增的方式,这里有多种方式以后会详细描述 -->
		</id>
		<property name="name" /><!-- 注意:这里填写的这些属性名一定要与Student类中的属性名一致 -->
		<property name="age" />
		<property name="sex" />
	</class>
</hibernate-mapping>

第六步,将我们写好的映射文件,配置到hibernate.cfg.xml配置文件中,在引入之前一定要检查你的映射文件和Bean类中的属性是否对应,否则还是无法自动创建表。

很简单只需要将 <mapping resource="com/mikyou/bean/student.hbm.xml" />这行代码放入到配置文件中,resource配置的是映射文件相对项目工程所在的路径

最终的配置文件的代码如下:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC
	"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
	"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
<hibernate-configuration>

	<session-factory>

		<!-- Database connection settings -->
		<property name="connection.driver_class">com.mysql.jdbc.Driver</property><!-- 数据库的驱动完整类名 ,根据自己需求替换-->
		<property name="connection.url">jdbc:mysql://127.0.0.1:3306/demo</property><!-- 数据库连接地址 /后跟数据库名,根据自己需求替换-->
		<property name="connection.username">root</property><!-- 用户名根据自己需求替换 -->
		<property name="connection.password">root</property><!-- 密码 根据自己需求替换-->

		<!-- JDBC connection pool (use the built-in) -->
		<property name="connection.pool_size">1</property>

		<!-- SQL dialect -->
		<property name="dialect">org.hibernate.dialect.MySQLDialect</property><!-- 设置相应数据库的方言根据自己需求替换 -->

		<!-- Enable Hibernate's automatic session context management -->
		<property name="current_session_context_class">thread</property>

		<!-- Disable the second-level cache -->
		<property name="cache.provider_class">org.hibernate.cache.NoCacheProvider</property>

		<!-- Echo all executed SQL to stdout -->
		<property name="show_sql">true</property><!--打印sql语句到控制台  -->
		<property name="format_sql">true</property><!--对打印到控制台的sql语句进行格式化  -->
		<!-- Drop and re-create the database schema on startup -->
		<property name="hbm2ddl.auto">update</property><!-- 自动建表 -->

		<mapping resource="com/mikyou/bean/student.hbm.xml" /><!-- 引入映射文件,里面为映射文件所在的路径 -->

	</session-factory>

</hibernate-configuration>

第七步,终于到了最后一步了,编写建表测试类并通过代码插入一条记录,并查看数据表是否建立成功,数据是否插入成功。

package com.mikyou.test;

import java.util.Date;

import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;
import org.hibernate.classic.Session;

import com.mikyou.bean.Student;

public class TableTest {
	public static void main(String[] args) {
		//1、创建配置对象
		Configuration config=new Configuration();
		//2、读取配置文件,
		config.configure();//注意这里有很多的重载的方法。默认是在src目录下加载配置文件
		//3、根据配置文件信息创建一级缓存,SessionFactory重量级对象,不要频繁创建
		SessionFactory factory=config.buildSessionFactory();
		//4、创建Session 打开会话

		Session session=factory.openSession();
		//5、开启事务
		Transaction transaction=session.beginTransaction();
		Student student=new Student(null, "Mikyou", 22, "男");
		session.save(student);
		//6、事务提交
		transaction.commit();
		//7、Session关闭
	}
}

测试结果:

通过测试结果发现,我们的表自动建立成功也就意味着我们的Hibernate环境搭建成功。

时间: 2024-12-31 03:54:52

浅谈JavaEE中的Hibernate环境的搭建(二)的相关文章

浅谈JavaEE中的Hibernate中的四种关系映射(三)

今天我们一起来探讨一下有关Hibernate四种关系映射,大家可能会有疑惑,关系映射不就是只有三种(一对一,一对多,多对多)吗?这里我们再多说一个继承映射关系,虽然它使用频繁度没有前三个那么多,但是它在一些特定情况下,还是非常有用的,至于有什么用下面马上就要讲.这些关系映射实际上就是对应着关系型数据库中的几种关系的类型.我们都知道Hibernate的作用是将面向关系数据操作,转换成面向对象的操作,其中关系映射文件就是实现这个转换的核心.我们都知道如果我们仅仅使用SQL语句建表并且去维护表与表之间

浅谈JavaEE中的JDBC模板类的封装实现以及合理的建立项目包结构(一)

从今天开始我们一起来聊下有关,javaEE开发中的一些知识,JavaEE的开发用于企业级的开发,但是现在企业中一般也不会使用JDBC开发,大部分都是使用自己公司开发的一套的框架,但是这些框架的架构一般也是会模仿着有名JavaEE开源三大开发框架SSH(Struts2+Spring+Hibernate)或者现在也很流行的SSM开发框架(Spring+SpringMVC+MyBatis) 来进行深度定制以便于适合自己企业的实际开发需求.有的人曾说既然去公司又是重新学习一套框架,还有必要学习开源的三大

浅谈js中的执行环境和执行环境对象

什么是js的"执行环境",每当函数被调用的时候,就会产生一个新的执行环境,它是运行中的函数的意思,比方说运动员在奔跑的环境中,我们可以把运动员在奔跑的环境中,说成奔跑中的运动员,以此类推说成运行中的函数,行话叫”执行环境“. 下面我们就以一个例子进行分析执行环境对象,以下是执行环境对象的第一轮 以上的这个参数和函数都已被声明和赋值,并且局部变量已被声明,这个就是第一轮,接下来就是要执行第二轮 由于在执行环境中可以调用函数,其中会有很多的深度,其中又会设计到很多比较复杂的函数调用以及作用

浅谈Linux中的信号机制(二)

首先谢谢 @小尧弟 这位朋友对我昨天夜里写的一篇<浅谈Linux中的信号机制(一)>的指正,之前的题目我用的“浅析”一词,给人一种要剖析内核的感觉.本人自知功力不够,尚且不能对着Linux内核源码评头论足.以后的路还很长,我还是一步一个脚印的慢慢走着吧,Linux内核这座山,我才刚刚抵达山脚下. 好了,言归正传,我接着昨天写下去.如有错误还请各位看官指正,先此谢过. 上篇末尾,我们看到了这样的现象:send进程总共发送了500次SIGINT信号给rcv进程,但是实际过程中rcv只接受/处理了1

浅谈hadoop中mapreduce的文件分发

最近在做数据分析的时候,需要在mapreduce中调用c语言写的接口,此时就需要把动态链接库so文件分发到hadoop的各个节点上,原来想自己来做这个分发,大概过程就是把so文件放在hdfs上面,然后做mapreduce的时候把so文件从hdfs下载到本地,但查询资料后发现hadoop有相应的组件来帮助我们完成这个操作,这个组件就是DistributedCache,分布式缓存,运用这个东西可以做到第三方文件的分发和缓存功能,下面详解: 如果我们需要在map之间共享一些数据,如果信息量不大,我们可

浅谈js中的this关键字

浅谈js中的this关键字 全局作用域中的this 函数作用域中的this 不同函数调用方法下的this 直接调用 作为对象的方法调用 作为构造函数调用 通过call或apply方法调用 嵌套函数作用域中的this 浅谈js中的this关键字 this是JavaScript中的关键字之一,在编写程序的时候经常会用到,正确的理解和使用关键字this尤为重要.接下来,笔者就从作用域的角度粗谈下自己对this关键字的理解,希望能给到大家一些启示,权当交流之用. 全局作用域中的this 本文将以作用域由

浅谈C#中堆和栈的区别(附上图解)

线程堆栈:简称栈 Stack 托管堆: 简称堆 Heap 使用.Net框架开发程序的时候,我们无需关心内存分配问题,因为有GC这个大管家给我们料理一切.如果我们写出如下两段代码: 代码段1: public int AddFive(int pValue) { int result; result = pValue + 5; return result; } 代码段2: public class MyInt { public int MyValue; } public MyInt AddFive(i

浅谈数据库系统中的cache(转)

http://www.cnblogs.com/benshan/archive/2013/05/26/3099719.html 浅谈数据库系统中的cache(转) Cache和Buffer是两个不同的概念,简单的说,Cache是加速"读",而buffer是缓冲"写",前者解决读的问题,保存从磁盘上读出 的数据,后者是解决写的问题,保存即将要写入到磁盘上的数据.在很多情况下,这两个名词并没有严格区分,常常把读写混合类型称为buffer cache,本文后续的论述中,统一

【转】浅谈Java中的equals和==

浅谈Java中的equals和== 在初学Java时,可能会经常碰到下面的代码: 1 String str1 = new String("hello"); 2 String str2 = new String("hello"); 3 4 System.out.println(str1==str2); 5 System.out.println(str1.equals(str2)); 为什么第4行和第5行的输出结果不一样?==和equals方法之间的区别是什么?如果在初