hibernate自定义主键策略

2014-11-24 00:57:38 · 作者: · 浏览: 0

hibernate自定义主键策略,
最近项目中使用hibernate的guid生成策略,配置如下:




发现生成的id很有规律,一看源码原来hibernate的guid底层使用采用数据库底层的guid算法机制,对应MYSQL的uuid()函数,SQL

Server的newid()函数,ORACLE的rawtohex(sys_guid())函数等。


具体oracle使用的是(select rawtohex(sys_guid()) from dual)
使用下面的pl/sql测试:


declare
v varchar2(32);
begin
for i in 0..10 loop
select rawtohex(sys_guid()) into v from dual;
dbms_output.put_line(v);
end loop;
end;


结果:
A36190EE69DDAAE7E040200A8A096CE5
A36190EE69DEAAE7E040200A8A096CE5
A36190EE69DFAAE7E040200A8A096CE5
A36190EE69E0AAE7E040200A8A096CE5
A36190EE69E1AAE7E040200A8A096CE5
A36190EE69E2AAE7E040200A8A096CE5
A36190EE69E3AAE7E040200A8A096CE5
A36190EE69E4AAE7E040200A8A096CE5
A36190EE69E5AAE7E040200A8A096CE5
A36190EE69E6AAE7E040200A8A096CE5
A36190EE69E7AAE7E040200A8A096CE5
只有中间一个字符不同。

下面采用hibernate自定id策略接口IdentifierGenerator
我们简单起见使用jdk自带的uuid方法:

public class UUIDGenerator implements IdentifierGenerator{

private static Logger logger = Logger.getLogger(UUIDGenerator.class);

public Serializable generate(SessionImplementor session, Object object)
throws HibernateException {
String id = UUID.randomUUID().toString().replaceAll("-", "").toUpperCase();

return id;
}

}


然后在配置的时候用如下配置即可:





~完~