【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整合的博客中会详细讲解,敬请期待吧!
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。