Hibernate主键生成策略
2016-06-10 13:06
267 查看
/** 在所有策略中,只有assigned策略的主键是自己定义的,其余在调用save/persist保存到数据库时会自动生成一个id,所以在这之前设置的id没有意义,其将被覆盖。 正常情况下enhanced-sequence可以满足选择,最好选择pre-insert类型的策略,特殊情况可以自己分配,需要分布式合并数据库可以使用uuid2 */ /* *JPA自带三种生成策略 * GenerationType.SEQUENCE:使用数据库序列,若数据库不支持序列则使用表,可与@SequenceGenerator配合使用不同名字的序列 * GenerationType.TABLE:使用数据表来记录序列,可与@TableGenerator配合往表里插入一条新的自增伪序列 * GenerationType.IDENTITY:使用数据库自增长字段,若不存在则出错 * GenerationType.AUTO:自动挑选最佳策略,一般为SEQUENCE/IDENTITY */ @Id @SequenceGenerator(name = "lala",sequenceName = "myseq") @GeneratedValue(strategy = GenerationType.SEQUENCE,generator = "lala") //一个实体的主键不能为int型 private long id; /** * 使用Hibernate内置的生成策略 * //以下为pre-insert id * 1.enhanced-sequence:与JPA的SEQUENCE同 * 2.native:同JPA的AUTO * 3.sequence:只使用数据库的序列,不支持时错误 * 4.enhanced-table:同JPA的TABLE * 5.seqhilo:高低位算法 * 6.increment:在Hibernate内部产生的自增序列,只适合非集群的环境。 * 7.uuid2:直接在save之前使用UUID生成一个128位的随机0/1序列,用于分布式合并库 * 8.guid:使用数据库生成uuid * 9.assigned:用户自己生成,可使用uuid自己分配,save时不会被覆盖 * //以下只能在插入时/插入后生成主键,getId可能返回null/0 * 9.sequence-identity:只使用数据库序列,不支持时错误 * 10.identity:同JPA的IDENTITY,不可使用Hibernate注解配置 */ @Id @GenericGenerator(name = "eq",strategy = "assigned") @GeneratedValue(generator = "eq") private String id;
相关文章推荐
- Android之获取手机上的图片和视频缩略图thumbnails
- 数据库链接字符串查询网站
- DB2实例管理
- DB2实例管理
- 保障MySQL数据安全的14个最佳方法
- mysql问答汇集
- 第三章 数据库备份和还原
- 创建一个空的IBM DB2 ECO数据库的方法
- Access 2000 数据库 80 万记录通用快速分页类
- 开通一个数据库失败的原因的和解决办法
- 一个简单的asp数据库操作类
- CentOS下DB2数据库安装过程详解
- EasyASP v1.5发布(包含数据库操作类,原clsDbCtrl.asp)第1/2页
- sql2008 还原数据库解决方案
- Oracle 数据库自动存储管理-安装配置
- Oracle数据库执行脚本常用命令小结
- Oracle 数据库 临时数据的处理方法
- 数据库分页查询语句数据库查询
- 最近比较流行的数据库挂马