hibernate annoation (三 id生成器)

id生成:

hibernate内不可使用的id生成器可见代码

使用@GeneratedValue

1 正对不同的数据库可以同时使用

  @Id
    @GeneratedValue(strategy = GenerationType.AUTO)

2 针对mysql

 @Id
 @GeneratedValue(strategy = GenerationType.IDENTITY)

3 针对oracle

  @Id
    @GeneratedValue(strategy = GenerationType.SEQUENCE,generator="s_gen")
    @SequenceGenerator(name="s_gen",sequenceName="s_seq")

说明:@GeneratedValue()的strategy属性支持5中id生成器:除上面3中外还有GenerationType.TABLE

2配合使用@GenericGenerator 不单独使用

hibernate内不可使用的id生成器可见代码

GENERATORS.put( "uuid", UUIDHexGenerator.class );
 GENERATORS.put( "hilo", TableHiLoGenerator.class );
 GENERATORS.put( "assigned", Assigned.class );
 GENERATORS.put( "identity", IdentityGenerator.class );
 GENERATORS.put( "select", SelectGenerator.class );
 GENERATORS.put( "sequence", SequenceGenerator.class );
 GENERATORS.put( "seqhilo", SequenceHiLoGenerator.class );
 GENERATORS.put( "increment", IncrementGenerator.class );
 GENERATORS.put( "foreign", ForeignGenerator.class );
 GENERATORS.put( "guid", GUIDGenerator.class );
 GENERATORS.put( "uuid.hex", UUIDHexGenerator.class ); // uuid.hex is deprecated
 GENERATORS.put( "sequence-identity", SequenceIdentityGenerator.class );
)

如果想要不同的表使用相同的主键生成器,可以把他的generator的name属性设为相同即可

例如:

@GeneratedValue(name="id1")
@GenericGenerator(name="id1",strategy="identity")

时间: 2024-08-22 14:25:06

hibernate annoation (三 id生成器)的相关文章

hibernate annoation(十一 缓存Ehcache 采用annoation)

从hibernate2.1开始ehcache已经作为hibernate的默认缓存方案(二级缓存方案 sessionfactory级别), 在项目中有针对性的使用缓存将对性能的提升右很大的帮助. 要使用 Ehcache:需要一下步骤 一,classpath添加相应的jar(ehcache,commons-logging) 二,然后在hibernate.cfg.xml中配置 <property name="cache.provider_class">org.hibernate.

基于redis的分布式ID生成器

项目地址 https://github.com/hengyunabc/redis-id-generator 基于redis的分布式ID生成器. 准备 首先,要知道redis的EVAL,EVALSHA命令: http://redis.readthedocs.org/en/latest/script/eval.html http://redis.readthedocs.org/en/latest/script/evalsha.html 原理 利用redis的lua脚本执行功能,在每个节点上通过lua

高并发下的Id生成器

考虑到sql server以及c#,最多只能用decimal类型,也就是29位的数字,做了下面这个数字型id生 成器: class Program { static void Main(string[] args) { int i = 100000; Timing t = new Timing(); t.Start(); while(i-->0) UniqueIdGenerator.Next(); t.Stop(); t.Display(""); } } public stati

hibernate annoation (四 lob)

hiberante sql映射对应 Java数据类型 Hibernate数据类型 标准SQL数据类型 (PS:对于不同的DB可能有所差异) byte.java.lang.Byte byte TINYINT short.java.lang.Short short SMALLINT int.java.lang.Integer integer INGEGER long.java.lang.Long long BIGINT float.java.lang.Float float FLOAT double

orm-关于hibernate实体类ID自增长的问题

问题描述 关于hibernate实体类ID自增长的问题 一个Java web项目,实体ID是这样的:BEIJING00000001 自增长的 用的ORM是hibernate. 现在用的自增长只能这么增长:1 ,2,3,4... 不能自己补上的前面的部分. 必须在服务层给补上或去掉,很满帆,不知道hibernate有解决这个问题更简单的方案吗? 解决方案 可以考虑Hibernate主键的 自定义主键生成策略. 配置如下: 写一个com.XXX.XXX.MYIDGenerator实现id策略接口Id

分布式ID生成器

最近会写一篇分布式的ID生成器的文章,先占位.借鉴Mongodb的ObjectId的生成: 4byte时间戳 + 3byte机器标识 + 2byte PID + 3byte自增id 简单代码: import com.google.common.base.Objects; import java.net.NetworkInterface; import java.nio.ByteBuffer; import java.util.Date; import java.util.Enumeration;

分布式ID生成器的剖析与设计

ID是身份标识,你所涉及的每类业务都会有一个,身份证, 手机号, QQ号.那么问题来了,如何设计一个算法,能快速生成ID又能有效地避免冲突.往小了说,在存储领域每一行数据都会有一个ID,关系型数据库有 auto increment, 非关系型数据库,如mongodb有自己的objectID 算法.对于各种ID我们可以简化为2类:1.去中心化,统一长度,规则占坑类, mongodb属于这一类, guid 属于这类类.2.中心化,ID自增,auto increment属于这一类. mongodb i

hibernate annoation (七 继承映射)

Table per Class Strategy: the <union-class> element in Hibernate Single Table per Class Hierarchy Strategy: the <subclass> element in Hibernate Joined Subclass Strategy: the <joined-subclass> element in Hibernate ejb支持三种映射关系 1,每个类一张表 (hi

hibernate annoation (二 创建表)

为了追踪hibernate的信息 <property name="hibernate.show_sql">true</property> 新建User类: @Entity @Table(name="E_USER",uniqueConstraints={ @UniqueConstraint(columnNames={"yahoo"}) }) public class User { private int id; privat