hibernate自定义主键策略, 最近项目中使用hibernate的guid生成策略,配置如下: <id name="id" type="java.lang.String"> <column name="ID" length="32" /> <generator class="guid" /> </id> 发现生成的id很有规律,一看源码原来hibernate的guid底层使用采用数据库底层的guid算法机制,对应MYSQL的uuid()函数,SQL
Server的newid()函数,ORACLE的rawtohex(sys_guid())函数等。
具体oracle使用的是(select rawtohex(sys_guid()) from dual) 使用下面的pl/sql测试:
结果: A36190EE69DDAAE7E040200A8A096CE5 A36190EE69DEAAE7E040200A8A096CE5 A36190EE69DFAAE7E040200A8A096CE5 A36190EE69E0AAE7E040200A8A096CE5 A36190EE69E1AAE7E040200A8A096CE5 A36190EE69E2AAE7E040200A8A096CE5 A36190EE69E3AAE7E040200A8A096CE5 A36190EE69E4AAE7E040200A8A096CE5 A36190EE69E5AAE7E040200A8A096CE5 A36190EE69E6AAE7E040200A8A096CE5 A36190EE69E7AAE7E040200A8A096CE5 只有中间一个字符不同。
下面采用hibernate自定id策略接口IdentifierGenerator 我们简单起见使用jdk自带的uuid方法:
然后在配置的时候用如下配置即可:
<id name="id" type="java.lang.String"> <column name="ID" length="32" /> <generator class="com.XXX.XXX.UUIDGenerator" /> </id> ~完~
Powered by: BlogJava Copyright © 疯狂