【SSH】之Hibernate

    接着上篇博客,这篇博客继续介绍SSH之Hibernate。想先说明一下,本文只是简单的介绍Hibernate,但为什么放在SSH里,是为了后面有一个SSH的整合。所以只是从最基本最简单的原理来讲解Hibernate。


    在开始之前我们最好先了解一下Hibernate。其实Hibernate本身是一个独立的、开放源码的对象关系型数据映射框架,它对JDBC进行了轻量级的封装,使得Java程序员可以随心所欲的使用对象编程的思想来操纵数据库。所以,简单的理解,可以把Hibernate理解成是和数据库打交道的框架。


    好,现在我们来说如何配置Hibernate.还是按照那三个步骤:jar包、hibernate.cfg.xml主配置文件和*.hbm.xml映射文件。现在,先说配置Hibernate需要哪些jar包。

技术分享

    现在说一下这些jar包的作用:

1、antlr-2.7.6.jar:一个语言转换工具,Hibernate利用它实现HQL到SQL的转换。它可以接受词文法语言面熟,并能产生识别这些语言的语句的程序。

2、c3p0-0.9.1.jar:C3P0连接池

3、commons-collections-3.1.jar:collections Apache的工具集,用来增强Java对集合的处理能力。使用javax.persistence下的Annotation可以不依赖Hibernate的jar包,这样可以切换到其他的ORM框架。

4、dom4j-1.6.1.jar:dom4j xml解析器。是一个java的xml api,类似于jdom。用来读写xml文件的。

5、hibernate3.jar:Hibernate的核心库,这个没什么说的,必须使用的jar包

6、hibernate-jpa-2.0-api-1.0.0.Final.jar:对JPA(Java持久化API)规范的支持。

7、javassist-3.12.0.GA.jar:代码生成工具,Hibernate用它在运行时扩展java类和实现,同cglib

8、jta-1.1.jar:标准的java事务处理接口

9、mysql-connector-java-5.1.5-bin.jar:java连接mysql的数据库驱动

10、slf4j-api-1.6.1.jar:Hibernate使用的一个日志系统


    好,下面说主配置文件:hibernate.cfg.xml,这个主配置文件是做什么用的?它里面都配置什么东西呢?下面我们就来具体说一下。Hibernate配置文件主要用于配置数据库连接和Hibernate运行时所需的各种属性。

<?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>	<pre name="code" class="javascript">         //1.数据库连接信息
	 <property name="dialect">
		 org.hibernate.dialect.MySQL5InnoDBDialect
 	</property>
                //后面要写数据库名字和mysql的用户名和密码
                 <property name="connection.url">jdbc:mysql://localhost:3306/******</property>
		 <property name="connection.driver_class">com.jdbc.mysql.Driver</property>
 		 <property name="connection.username">****</property>
		 <property name="connection.password">****</property> 


	//2.其他配置 (这些有一个共同的特点,就是这些不配是可以的)
        //显示SQL语句 
	<property name="show_sql">true</property>
        //自动建表,update的意思就是不要每次都重建(每次都重建,数据就没了)
	 <property name="hbm2ddl.auto">update</property>
        //自动建表
	<!-- <property name="hbm2ddl.auto">create</property> -->

        //3.导入映射文件
	<mapping resource="cn/itcast/oa/domain/User.hbm.xml" />
        //原来role的实体和映射文件写好了,就是映射不到数据库中去,就是因为这个原因Hibernate.cfg.xml配置文件中没有配
	<mapping resource="cn/itcast/oa/domain/Role.hbm.xml" />
	<mapping resource="cn/itcast/oa/domain/Department.hbm.xml" />

</session-factory>
</hibernate-configuration>

看配置文件里的信息注意看这句话:
//1.数据库连接信息
<property name="dialect">
     org.hibernate.dialect.MySQL5InnoDBDialect
</property>

这个是Hibernate主配置文件中配置的mysql方言,那么什么是方言呢?因为不同的数据库,在SQL语句设计上是存在差异的,就好比不同地方的人说不同的方言,Hibernate到哪个数据库哪里就要说哪个数据库的“方言”。而我们要做的就是配置方言选项,告诉Hibernate要说哪里的方言。


那么这个方言我们不会写啊,这个不用记的。去哪里找呢?跟我来。首先打开类型,Ctrl+Shift+t

技术分享

所有的方言都是有类名的,而且这个方言还有特点,开头是数据库类型,结尾是方言结尾。

mysql*dialect这个就是mysql的方言

技术分享

所以相对应的Oracle方言就是这样

技术分享

Sql Server的方言如下:

技术分享

所以按照这样的方式,选择一个就可以了。


    好了,下面说*.hbm.xml映射文件。什么是映射文件呢?映射文件是用来定义Hibernate的持久化类和关系数据库之间的映射。这个映射文件是通过一系列的xml元素的配置,来将持久化类与数据库表之间建立起一一映射,这意味着映射文档是按照持久化类的定义来创建的,而不是表的定义。

    所以简单来说,映射文件是Hibernate与数据库进行持久化的桥梁,是设定数据库表与实体类进行关联,让用户以面向对象的方式去操作持久化类,也就是实体bean,而不再是操作数据库表,免去了用户频繁书写sql语句的麻烦。我们以User的映射文件User.hbm.xml为例,代码如下:

<?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 package="cn.itcast.oa.domain">

	<class name="User" table="itcast_user">
		<id name="id">
			//这个地方,主键生成策略,我们采用native 
            <generator class="native"/>
		</id>
		<property name="loginName" />
		<property name="password" />
		<property name="name" />
		<property name="gender" />
		<property name="phoneNumber" />
		<property name="email" />
		<property name="description" />
		
		//department属性, 本类与Department的多对一的关系 
		//name属性名 ;  class类型,指关联谁  ;column列,指哪个外键
		 <many-to-one name="department" class="Department" column="departmentId"></many-to-one>
		
		
		//roles属性,本类与Role的多对多的关系 -->
		//一对多和多对一有一个外键,但是多对多有两个外键 -->
		//所以多对多比多对一多两个字段。多一个Table,多一个外键column -->
		<set name="roles" table="itcast_user_role">
			<key column="userId"></key>
			<many-to-many class="Role" column="roleId"></many-to-many>
		</set>
		
	</class>
</hibernate-mapping>


    其实Hibernate的学习还远不止此,这篇博客只是简单的配置一下Hibernate,但是要继续研究的东西还很多。在SSH整合的时候我们会对主配置文件进行更进一步的划分,等在SSH整合的博客中会详细讲解,敬请期待吧!

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。