org.hibernate.id.SequenceHiLoGenerator
HiLo算法即id=hi*(max_lo+1)+lo,lo值在1到max_lo直接循环,lo值每循环一圈,hi值就增一。可以这么理解max_lo(当然实际有一点差别,在于lo取值从1~max_lo,而不是0~max_lo-1):
hi = id / max_lo
lo = id % max_lo
如果max_lo=3,hi的初始值是1,那么生成的id序列是:
4+1 = 5
4+2 = 6
4+3 = 7
4+4 = 8
(此时hi = 2)
8+1 = 9
8+2 = 10
8+3 = 11
...
使用一个高/低位算法生成的long、short或int类型的标识符,给定一个表和字段作为高位值的来源,默认的表是hibernate_unique_key,默认的字段是next_hi。它将id的产生源分成两部分,DB+内存,然后按照算法结合在一起产生id值,可以在很少的连接次数内产生多条记录,提高效率
MySQL:create table hi_value(next_hi integer not null);
insert into hi_value(next_hi) values(1);
<id name="id" column="id">
<generator class="hilo">
<param name="table">hi_value</param>
<param name="column">next_hi</param>
<param name="max_lo">100</param>
</generator>
</id>
在hibernate持久化的时候,由hibernate负责生成低位值。hilo标识符生成器在生成标识符时需要从hi_value表中取出next_hi的当前值,然后修改该值,这个操作是在单独的事务中完成的。最大的低值在属性max_lo中配置,但在Hibernate内存中生成的低位值超过此值时,就有需要到数据库的hi_value表中再次读取高位值了
使用hilo生成策略,要在数据库中建立一张额外的表,默认表名为hibernate_unique_key,默认字段为integer类型,名称是next_hi(比较少用)
我们也可以自己设置自定义的表名和字段名
<id name="id" type="integer">
<column name="id"/>
<generator class="hilo">
<param name="my_unique_key"/>
<param column="next_hi"/>
</generator>
</id>
本文深入探讨了HiLo算法在数据库ID生成中的应用,通过实例展示了如何利用该算法在Hibernate框架下创建高效且独特的标识符,包括算法原理、MySQL实现方式以及在持久化过程中的具体应用。
2126

被折叠的 条评论
为什么被折叠?



