- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Hibernate的主键生成器集锦
Hibernate的主键生成器集锦
(1) increment
对long、int或short的数据列生成自动增长主键。这种情况主要用于数据库中未把表格主键设置为自增,而又想表格主键自增时。
此方式的实现机制为在当前应用实例中维持一个变量,以保存着当前的最大值,之后每次需要生成主键的时候将此值加1作为主键。
这种方式可能产生的问题是:如果当前有多个实例访问同一个数据库,那么由于各个实例各自维护主键状态,不同实例可能生成同样的主键,从而造成主键重复异常。因此,如果同一数据库有多个实例(也就是并发量大的)访问,此方式必须避免使用。 只有在没有其他进程往同一张表中插入数据时才能使用。但是它的生成标识符机制不依赖于底层数据库系统,所以他适合于所有的数据库系统。
(2)identity
对如SQL Server,MySQL等支持自动增长列的数据库,如果数据列的类型是long、short或int,可使用该主键生成器来生成自动增长主键。但由于它依赖于底层数据库,所以要求底层数据系统必须支持自动增长字段类型。而且它需要底层数据库把主键定义为自动增长字段类型。
(3)native
该生成器依据底层数据库对自动生成标识符的支持能力,来选择使用identity、sequence或hilo标识符生成器。能自动判断底层数据库提供的生成标识符的机制。
适合于跨数据库平台开发,即同一个Hibernate应用需要连接多种数据库系统的场合。
(4)sequence
对如Oracle,DB2等支持Sequence的数据库,如果数据列的类型是long,short或int,可使用该主键生成器生成自动增长主键。 该标识符生成器利用底层数据库提供的序列来生成标识符。
generator class=sequence
param name=sequencetester_id_seq/param
/generator
在生成的DDL代码中会生成:
create sequence tester_id_seq;
注:MySQL不支持sequence。
当Hibernate在持久化一个SequenceTester对象时,先从底层数据库的tester_id_seq序列中获得一个唯一的序列号,再把它作为主键值。注意:要求底层数据库必须支持序列,包括:Oracle、DB2、SAP DB、PostgreSQL等。
自动生成的意思是你指定一个序列给hibernate,hibernate会找到序列的下一个值给你的主键
比如你创建一个序列CREATE SEQUENCE user_id_seq INCREMENT BY 1 -- 每次加1
START WITH 1:从1开始计数; NOMAXVALUE:不设置最大值; NOCYCLE:一直累加,不循环 ;NOCACHE :不建缓冲区;然后在映射文件里面把这个序列指定给hibernate,让序列与某个主键相关联,然后hibernate就知道如何自增了!!
id name=id column=USER_ID
generator class=sequence
param name=sequenceuser_id_seq/param
/generator
/id
(5)uuid.hex
由Hibernate基于128 位唯一值产生算法生成16 进制数值(编码后以长度32 的字符串表示)作为主键。
(6)uuid.string
与uuid.hex 类似,只是生成的主键未进行编码(长度16)。在某些数据库中可能出现问题(如PostgreSQL)
(7) Assigned
主键由外部程序负责生成,无需Hibernate参与。
(8)hilo标识符生成器
hilo标识符生成器由HIbernate按照一种high/low算法来生成标识符,他从数据库的特定表字段中获取high值
id name=id type=long column=ID
generator class=hilo
param name=tablehi_value/param
param name=columnnext_value/param
param name=max_lo100/param
/generator
/id
上例:high值放在hi_value表的next_value字段中
Hibernate 在持久化一个对象时,需要读取并修
您可能关注的文档
最近下载
- LNGT88J永磁合金工艺研究.docx VIP
- 最校苏教版五年级数学同步思维训练(上册).pdf VIP
- 外研版高中英语选择性必修一Unit-3-The-road-to-success.pptx VIP
- 众兴菌业培训课件.pptx VIP
- 房地产市场年报-2020年天津市房地产市场年报.pdf VIP
- 1. 香港公司註冊證明書.pdf VIP
- 【港交所-2025研报】卓能(集团) 截至二零二四年十二月三十一日止六个月中期业绩报告.pdf VIP
- 2025四川内江市隆昌市兴晟产业投资集团有限公司招聘13人考试备考题库及答案解析.docx VIP
- ISO9001、ISO14001、ISO45001三标一体内部审核检查表.pdf VIP
- 2019年天津房地产市场回顾及2020年展望 .pdf VIP
文档评论(0)