Hibernate入门3.配置映射文件深入 2013.11.27

前言:

之前的两节是在Java项目中如何使用hibernate,并且通过一个简单地项目实践,期间有很多的错误,一般都是因为配置包的问题,比如日志输出、slf4j对应的版本等等。其实官方网站下载的hibernate和Spring也是不可靠的,因为这些报的运行也需要其他的包的支持。所以及时自己在IED编辑的时候,没有出现“红线”不一定代表就会正确的编译运行。如果程序运行的时候缺少包的话,一定要养成习惯去对应的官方网站下载,有时候对应的版本也十分重要。

这一节继续深入的学习Hibernate的配置文件和ORM映射文件

1.Hibernate配置文件

对于配置文件的方式:hibernate.properties方式、hibernate.cfg.xml方式和两者结合使用。

常用的配置属性:

hibernate.dialect: 针对不同的数据库提供不同的方言类,允许hibernate针对特定的数据库生成优化的SQL语句。

hibernate.connection.driver_class:

hibernate.connection.url

hibernate.connection.username

hibernate.connection.password

hibernate.connection.pool_size

hibernate.connection.datasource//数据源的JNDI名字

hibernate.show_sql:是否输出Hibernate操作数据库的时候执行的sql

hibernate.format_sql:是否格式化的输出sql语句

hibernate.hbm2ddl.auto: 自顶向下,从持久化类导数据库的操作,有几个选择的值:create(每一次都会重新生成表),create-drop(创建之后,当sessionFactory关闭的时候,就会自动删除),update,validate(只是比较,不会创建表)

需要解释的是hibernate.dialect:

不同的数据库对应不同的方言类:

DB2                   org.hibernate.dialect.DB2Dialect

SQL server        org.hibernate.dialect.SQLServerDialect

MySQL               org.hibernate.dialect.MySQLDialect

Oracle9i            org.hibernate.dialect.Oracle9iDialect

Sybase               org.hibernate.dialect.SybaseDialect

对于使用properties方式配置的,这里是没有ORM Mapper的配置信息,所以需要使用configuration.addResource(“com.yang.model.mapper…”)一个一个的加载,其中hibernate.properties配置文件必须在根目录下面。

当然两者是可以联合使用的。

<?xml version="1.0" encoding="UTF-8"?>

<!DOCTYPE hibernate-configuration PUBLIC

"-//Hibernate/Hibernate Configuration DTD 3.0//EN"

"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">

<hibernate-configuration>

<session-factory>

<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>

<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>

<property name="hibernate.connection.url">jdbc:mysql://localhost:3306/test??useUnicode=true&amp;characterEncoding=utf8</property>

<property name="hibernate.connection.username">root</property>

<property name="hibernate.connection.password">221256</property>

<property name="hibernate.show_sql">true</property>

<property name="hibernate.hbm2ddl.auto">update</property>

<!--

<property name="hibernate.format_sql">true</property>

-->

<!-- 注册所有的ORM映射文件 -->

<mapping resource="com/yang/model/mapper/User.hbm.xml"/>

</session-factory>

</hibernate-configuration>

2.Hibernate映射文件

映射文件的根元素是<hibernate-mapping>该元素之下,可以有很多class元素,每一个class元素对应一个持久化类的映射。

映射文件的结构如下:

<hiberbate-mapping  属性=”值”>

<class name=”PackageName.ClassName” table=”tableName”>

<id name=”主键名” column=”主键列”>

<generator class=”生成策略”/>

</id>

<!—属性列表-->

<property name=”userName” column=”columnName” type=”数据类型”/>

</class>

</hibernate-mapping>

         其中<hibernate-mapping>元素的可选属性如下:

schema: 指定映射数据库的schema名

catalog:指定数据库的Catalog名字

default-cascade: 设置hibernate的默认级联风格,默认是none

default-access:设置默认属性的访问策略,默认是property

default-lazy:设置默认的延迟加载策略,默认是true

auto-import:是否允许使用非全限定的类名,默认是ture

package:指定一个包,对于映射文件中非全限定的类名,默认在该包下

         而class的元素常见的属性有:

name: 持久化类名

table:持久化类映射表名

discriminator-value:区分不同子类的值

mutable:指定的持久化了的实例是否可变,默认是true

proxy:延迟装载的代理,可以是该类自己的名字

         主键生成器

Hibernate映射文件中的<id>元素定义了持久化类的标识符属性(主键),其generator子元素则用来设置当前持久化类的标识符属性的生成策略。在hibernate中内置了很多的主键生成器

increment: 获取数据库中的主键最大值,然后加1

identity:自动增长。 MySQL SQL Server 等可以设置表的都一个字段是自动增长的,此种方式生成主键的数据类型可以是long short int和对应的封装类的类型

sequence:序列,数据库中如Oracle DB2中可以创建一个序列,然后从序列中获取当前序列号作为主键值。

还有hilo, seqhilo, uuid, guid, native, assigned, foreign等等多种方法。在MYSQL中推荐使用identity或者是native。如果使用分布式部署数据库的话,推荐使用uuid,也就是采用128位的UUID算法生成一个字符穿类型的主键。

<?xml version="1.0" encoding="UTF-8"?>

<!DOCTYPE hibernate-mapping PUBLIC

"-//Hibernate/Hibernate Mapping DTD 3.0//EN"

"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">

<hibernate-mapping>

<class name="com.yang.model.User" table="user">

<id name="id" column="id">

<generator class="native"/>

</id>

<property name="userName" column="username" type="string" not-null="true"/>

<property name="password" column="password" type="string" not-null="true"/>

</class>

</hibernate-mapping>

3.持久化对象

Hibernate持久化对象的几个状态:

瞬时状态:对象使用new关键字创建,尚未与Hibernate的Session关联,此时的对象处于瞬时状态(Transient)瞬时状态的对象时不会保存到数据库的,也不会赋予持久化标注,如果程序中失去了瞬时状态对象的引用,那么他也会被垃圾回收机制回收

持久化状态(Persistent):它和数据库表中的一条记录相对应,并且有一个持久化的标识。持久化对象时可以刚刚爆保存的或者是刚被加载的。持久化状态的对象必须和指定的Session关联,他的改动Hibernate都会检测到,并且在Session关闭或者Transaction提交的同时更新数据库中对应的数据,开发者不需要手动执行UPDATE

托管状态(Detached):曾经处于持久化状态,与之关联的Session被关闭,对象就会被托管了。

改变持久化对象的方法:使用Session中的接口方法对持久化对象状态产生的影响:

save():保存持久化对象,在数据库中新增加一条数据

saveOrUpdate()保存或者是更新,该方法根据id标签的unsaved-value属性值决定执行新增加一条记录或者是更新。

get()根据标识符属性获得一个持久化对象,如果未找到,则返回null

load()该方法根据标识符属性加在一个持久化对象,如果未找到,则抛出异常

update() 该方法对托管状态的对象重新完成持久化,更新数据库中的数据

delete()删除数据库中的一条记录,不过需要先使用get() or  load() 获取持久化对象

close()关闭当前的session对象,并且清空该对象中的数据

evict()用于清除session缓存中的某一个对象

clear()清除Session中的所有缓存对象。

YangTengfei

2013.11.28

Hibernate入门3.配置映射文件深入的更多相关文章

  1. Hibernate课程 初探多对多映射2-3 配置映射文件

    本节主要内容:配置映射文件 Project.hbm.xml <hibernate-mapping> <class name="com.ddwei.entity.Projec ...

  2. hibernate hbm.xml配置映射

    <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.sp ...

  3. Eclipse从数据库逆向生成Hibernate实体类和映射文件(Eclipse插件系列之HibernateTools)

    ♣下载安装Eclipse插件(HibernateTools) ♣Eclipse连接数据库(Mysql5.7) ♣新建hibernate.properties和hibernate.cfg.xml文件 ♣ ...

  4. 三 MyBatis配置文件SqlMapCofing.xml(属性加载&类型别名配置&映射文件加载)

    SqlMapCofing:dtd,属性加载有固定的顺序Content Model properties:加载属性文件 typeAliases:别名配置 1 定义单个别名:不区分大小写 核心配置: 映射 ...

  5. Hibernate 5 入门指南-基于映射文件

    由于Hibernate 4版本混乱,Hibernate 3有些过时,Hibernate 5的开发文档尚不完善,所以构建一份简单的Hibernate 5的入门指南 注:案例参考Hibernate 官方参 ...

  6. 概述hibernate入门安装配置

    1.jdbc连接的优缺点 JDBC的优点 直接底层操作,提供了很简单.便捷的访问数据库的方法,跨平台性比较强.灵活性比较强,可以写很复杂的SQL语句. JDBC的缺点 1).因为JAVA是面向对象的, ...

  7. 反向生成hibernate实体类和映射文件

    工欲善其事,必先利其器.我们可以使用IDE来根据数据库中的表反向生成实体类和映射文件,虽然这些东西手写也并不是难度很大,但是如果存在大量的简单工作需要我们做,也会显得很麻烦. 写在前面 我们反向生成的 ...

  8. hibernate用注解替代映射文件

    1.首先把原来的映射文件删掉,给实体类添加注解: @Entity //声明当前类为hibernate映射到数据库中的实体类 @Table(name="news") //声明tabl ...

  9. hibernate课程 初探一对多映射2-5 创建持久化类并配置映射文件

    学习点: 1 一对多映射,一方 Grade.hbm.xml的写法: <hibernate-mapping> <class name="com.ddwei.entity.Gr ...

随机推荐

  1. MFC下无法为空间添加变量解决

    许久不用MFC,今天在vs2008下用MFC写个小东西,结果在为控件添加变量的时候,居然无法成功——那个界面显示怪怪的,点击完成提示失败.    还好同事遇到过这个问题,给出链接http://hi.b ...

  2. 关于内存数据与 JSON

    闲话: 正在用 WebBroker 写一个小网站,感受颇多: 1.如果是写一个小东西,应该先考虑下 WebBroker,因为它是分分钟即可上手的. 2.如果要写一个大东西,或许也应该考虑下 WebBr ...

  3. C# 读写excel 用于导入数据库 批量导入导出excel

    给大家介绍一款控件,Aspose.Cells.dll,相当强大,几乎就是excel,支持excel2003,excel2007等格式文件.excel2010以上,没有经过测试,估计也是可以. Aspo ...

  4. LeetCode OJ--Minimum Window Substring ***

    https://oj.leetcode.com/problems/minimum-window-substring/ 模拟题 这道题细节比较多.从左到右扫一遍模拟着做 class Solution { ...

  5. HDU 5024 Wang Xifeng's Little Plot (DP)

    题意:给定一个n*m的矩阵,#表示不能走,.表示能走,让你求出最长的一条路,并且最多拐弯一次且为90度. 析:DP,dp[i][j][k][d] 表示当前在(i, j)位置,第 k 个方向,转了 d ...

  6. nodejs:csv模块解析

    Nodejs最大的特点就是基于事件驱动和异步并发操作.大多数人知道nodejs是用于网络后台服务的新平台,可以很方便的提供后台服务:除了用于网络开发外,其实nodejs对于线下文件并发处理也是很方便的 ...

  7. C语言误区

    int date[10] ; //定义一个字长10的数组,从date[0]....date[9] static   char   c ;   //静态变量(有静态外部变量和静态局部变量),静态外部变量 ...

  8. 『TCP/IP详解——卷一:协议』读书笔记——08

    2013-08-21 13:56:23 3.3 IP路由选择 1. IP路由选择有两种情况.(1)如果目的主机与源主机直接相连(如点对点链路)或都在一个共享网络上(以太网或令牌环网),那么IP数据报就 ...

  9. mysql Blob存取的一个简单例子

    一.得到mysql的连接 这里封装成一个方法,方便后面使用. public Connection getConnection() throws Exception{ String url = &quo ...

  10. SQL到NOSQL的思维转变

    NOSQL系统一般都会宣传一个特性,那就是性能好,然后为什么呢?关系型数据库发展了这么多年,各种优化工作已经做得很深了,NOSQL系统一般都是吸收关系型数据库的技术,然后,到底是什么因素束缚了关系型数 ...