“assigned” 
  
主键由外部程序负责生成,在   save()   之前指定一个。   
    
  
“hilo” 
  
通过hi/lo   算法实现的主键生成机制,需要额外的数据库表或字段提供高位值来源。    
    
  
“seqhilo” 
  
与hilo   类似,通过hi/lo   算法实现的主键生成机制,需要数据库中的   Sequence,适用于支持   Sequence   的数据库,如Oracle。    
    
  
“increment” 
  
主键按数值顺序递增。此方式的实现机制为在当前应用实例中维持一个变量,以保存着当前的最大值,之后每次需要生成主键的时候将此值加1作为主键。这种方式可能产生的问题是:不能在集群下使用。    
    
  
“identity” 
  
采用数据库提供的主键生成机制。如DB2、SQL   Server、MySQL   中的主键生成机制。    
    
  
“sequence” 
  
采用数据库提供的   sequence   机制生成主键。如   Oralce   中的Sequence。    
    
  
“native” 
  
由   Hibernate   根据使用的数据库自行判断采用   identity、hilo、sequence   其中一种作为主键生成方式。 
  
    
  
“uuid.hex” 
  
由   Hibernate   基于128   位   UUID   算法   生成16   进制数值(编码后以长度32   的字符串表示)作为主键。 
  
  
“uuid.string” 
  
与uuid.hex   类似,只是生成的主键未进行编码(长度16),不能应用在   PostgreSQL   数据库中。 
    
  
“foreign” 
  
使用另外一个相关联的对象的标识符作为主键。 
<id>元素中的<generator>用来为该持久化类的实例生成唯一的标识,hibernate提供了很多内置的实现。 
Increment:由hibernate自动递增生成标识符,用于为long, short或者int类型生成唯一标识。 
identity :由底层数据库生成标识符(自动增长),返回的标识符是 long, short 或者int类型的。 
sequence :hibernate根据底层数据库序列生成标识符,返回的标识符 是long, short或者 int类型的。 
hilo     :使用一个高/低位算法来高效的生成long, short 或者int类型的标识符。 
uuid.hex :用一个128-bit的UUID算法生成32位字符串类型的标识符。 
native   :根据底层数据库的能力选择identity, sequence 或者hilo中的一个。 
assigned :让应用程序在save()之前为对象分配一个标示符。 
foreign :使用另外一个相关联的对象的标识符。和<one-to-one>联合一起使用。

一、id生成方式 
1,序列sequence 只适用于Oracle 
<id name="id" column="id"> 
<generator class="sequence"> 
<param name="sequence">person_seq</param><!--指定sequence名--> 
</generator> 
</id> 
2,自增列,适用于SQLServer、MySql 
<id name="id" column="id"> 
<generator class="identity"/> 
</id> 
3,取最大值加一 
<id name="id" column="id" type="integer"> 
<generator class="increment"/> 
</id> 
4,根据底层数据库指定生成方法 
<id name="id" column="id"> 
<generator class="native"/> 
</id> 
使用缺省策略 
针对Oracle数据库的生成方式还是sequence,只不过需要一个特定名字的sequence,"hibernate_sequence"。 
5,高低位算法 
<id name="id" column="id"> 
<generator class="hilo"> 
<param name="table">high_value</param> 
<!--设置高位值取值的表--> 
<param name="column">next_value</param> 
<!--设置高位值取值的字段--> 
<param name="max_lo">50</param> 
<!--指定低位最大值,当取道最大值是会再取一个高位值再运算--> 
</generator> 
</id> 
以上是hilo算法的普通形式,不适合用于squenece 
在一个会话中保存多个对象 
二、Hibernate中对类关系的处理: 
one―to―one关系在数据库中如何体现,在JavaBean中如何体现,在 
Hibernate中如何映射one-to-one关系。            
1、 数据库中:一个表的外健对应另一个表的主健,外健要加上Unique约束(外健关联)。或者是两个表共享一个主健,表现为子表中的pk同时引用了父表的pk作外健而存在(主健关联,子表中的pk和fk为一个字段)。 
2、 javaBean中:在JavaBean中增加一个属性,即另外一个对象的引用,可以单向也可以双向。 
3、 在hibernate中: 
A、主健映射:都是one-to-one要用foreign生成策略。 
以汽车car和发动机Engine(一对一关系)为例: 
a、主表Car.hbm.xml的写法 
<class name="Car" table="car_pk"> 
<id name="id" column="id" type="integer"> 
<generator class="native" /> 
</id> 
<property name="name" column="name" type="string" /> 
<one-to-one name="engine" class="Engine" cascade="all"/> 
</class> 
注:cascade="all" 表示增删改查Car对象时都会级联增加、删除和修改Engine对象。 
级联一定是在主对象的映射文件中 
b、附表Engine.hbm.xml的写法 
<class name="Engine" table="engine_pk"> 
<id name="id" column="id" type="integer"> 
<generator class="foreign"> 
<param name="property">car</param> 
</generator> 
</id> 
<property name="model" column="model" type="string" /> 
<one-to-one name="car" class="Car" c/> 
</class> 
注:c表示Engine应用了Car的主健作为外健。 
foregin表明id的生成方式是引用表car的主键 
B、外健映射:主表中用one-to-one,通过property -ref many-to-one 
a、主表Car.hbm.xml的写法 
<class name="Car" table="car_fk"> 
<id name="id" column="id" type="integer"> 
<generator class="native" /> 
</id> 
<property name="name" column="name" type="string" /> 
<one-to-one name="engine" class="Engine" 
property-ref="car" cascade="save-update"/> 
</class> 
注:name="engine" property-ref="car"表示engine表引用了car表的主健作为他的外健。 
cascade="save-update"表示增改Car对象时都会级联增加和修改Engine对象。 
b、附表Engine.hbm.xml的写法 
<class name="Engine" table="engine_fk"> 
<id name="id" column="id" type="integer"> 
<generator class="native" /> 
</id> 
<property name="model" column="model" type="string" /> 
<many-to-one name="car" class="Car" 
unique="ture"  column="carid"/> 
</class> 
注:unique="ture" column="carid"表示为engine表中的外健carid加上唯一约束,使之一对多关系强制转化为一对一关系。

http://www.cnblogs.com/gywbg --------------GYW

hibernate generator class="" id详解的更多相关文章

  1. [转]hibernate缓存机制所有详解

    以下文章来自http://www.blogjava.net/tbwshc/articles/380013.html Hibernate 所有缓存机制详解 hibernate提供的一级缓存 hibern ...

  2. [转]hibernate三种状态详解

    本文来自 http://blog.sina.com.cn/u/2924525911 hibernate 三种状态详解 (2013-04-15 21:24:23) 转载▼   分类: hibernate ...

  3. hibernate(七) hibernate中查询方式详解

    序言 之前对hibernate中的查询总是搞混淆,不明白里面具体有哪些东西.就是因为缺少总结.在看这篇文章之前,你应该知道的是数据库的一些查询操作,多表查询等,如果不明白,可以先去看一下 MySQL数 ...

  4. hibernate(五) hibernate一对一关系映射详解

    序言 之前讲解了一对多(单向.双向).多对多(双向),今天就讲解一下最后一个关系,一对一. 心情不错.状态也挺好的,赶紧写一篇博文造福一下大家把. --WH 一.一对一关系的概述 一对一关系看起来简单 ...

  5. Hibernate入门(二)——hibernateAPI详解

    Hibernate API 详解 1.Configuration 功能:配置加载类,用于加载主配置,orm元数据加载 .创建: Configuration conf = new Configurati ...

  6. Hibernate学习(五)———— hibernate一对一关系映射详解

    一.一对一关系的概述 一对一关系看起来简单,其实也挺复杂的.其中关系就包含了四种,单向双向和主键关联外键关联. 什么意思呢,也就是包含了单向一对一主键关联.双向一对一主键关联,单向一对一外键关联,双向 ...

  7. 分布式ID详解(5种分布式ID生成方案)

    分布式架构会涉及到分布式全局唯一ID的生成,今天我就来详解分布式全局唯一ID,以及分布式全局唯一ID的实现方案@mikechen 什么是分布式系统唯一ID 在复杂分布式系统中,往往需要对大量的数据和消 ...

  8. Hibernate学习(七)———— hibernate中查询方式详解

    序言 之前对hibernate中的查询总是搞混淆,不明白里面具体有哪些东西.就是因为缺少总结.在看这篇文章之前,你应该知道的是数据库的一些查询操作,多表查询等 --WH 一.hibernate中的5种 ...

  9. hibernate generator class=xxx id详解

    <id>元素中的<generator>用来为该持久化类的实例生成唯一的标识,hibernate提供了很多内置的实现.Increment:由hibernate自动递增生成标识符, ...

随机推荐

  1. python安装MySQLdb(Windows环境)

    1.下载 http://www.codegood.com/downloads 我的win7 64位.Python2.7.8版本,所以选择MySQL-python-1.2.3.win-amd64-py2 ...

  2. LINQ Enumerable 续

    筛选序列 Enumerable.Distinct 对于复杂的对象列表,运行时引擎如何才能通过比较确定两个对象是否重复?对于复杂对象,必须提供一个比较器,即实现IEqualityComparer(Of ...

  3. yii2 添加模块过程

    本文以Yii2基本应用程序模板为例,介绍下向该框架下加入新模块的过程: 1. 新建模块相关目录与文件 step 1: 新建目录结构   首先在根目录下新建modules目录,然后在该目录下面添加模块目 ...

  4. php的一些基本概念梳理

    楼主是个刚参加工作的菜鸟,这几天刚开通博客园微博,想通过这个平台与大家共同学习与分享一些技术知识. 但是楼主犹豫的好久,不知道第一篇该写点什么.最后我决定先从php的一些基本概念开始,以便加深对各个概 ...

  5. spring aop切面配置

    <bean id="aopLog" class="sardine.commodity.biz.AopLog"/>    <aop:config ...

  6. 微信php接入设计案列

    <?php namespace Home\Controller; use Think\Controller; use Com\Wechat; use Com\WechatAuth; class ...

  7. JQUERY1.9学习笔记 之基本过滤器(七) 语言选择器

    语言选择器 jQuery( ":lang(language)" ) 描述:选择所有用特定语言指定的标签. 根据标签指定语言的不同给标签上色. <!DOCTYPE html&g ...

  8. PHP高效的敏感词过滤方法

    <?php // 测试文件demo.php $badword = array( '张三','张三丰','张三丰田' ); // array_combine() 函数通过合并两个数组来创建一个新数 ...

  9. bat(传参情况下)取得当前bat所在的目录路径

    在传参情况下,取得bat文件所在的目录路径,可以使用: %~dp0 说明: 01.所谓传参情况是指,将某个文件拖放到bat文件上并放开.此种情况下执行的bat命令就是有带参数的. 02.上面末尾的0是 ...

  10. php加密解密实用类

    一个加解密类.如果你想在用户忘记密码时为他或她找回原来的密码,那么这个类是个好用的工具 用户注册的密码一般不会明文保存,总得加个密先.最简单的当然是在数据库sql语句中调用md5函数加密用户密码.这里 ...