Sql 休眠手动和自动生成的主键
我有一个要求,如果用户为主键输入值,那么我需要在创建实体时使用该值,如果用户不提供值,则需要像R00001一样自动生成主键,R0002等。我想知道我如何实现这一点,以及关于这一点的任何指导尝试利用Sql 休眠手动和自动生成的主键,sql,hibernate,jpa,orm,primary-key,Sql,Hibernate,Jpa,Orm,Primary Key,我有一个要求,如果用户为主键输入值,那么我需要在创建实体时使用该值,如果用户不提供值,则需要像R00001一样自动生成主键,R0002等。我想知道我如何实现这一点,以及关于这一点的任何指导尝试利用IdentifierGenerator接口,并定义自己的实现 public class MyEntityIdGenerator implements IdentifierGenerator{ public Serializable generate(SessionImplementor ses
IdentifierGenerator
接口,并定义自己的实现
public class MyEntityIdGenerator implements IdentifierGenerator{
public Serializable generate(SessionImplementor session, Object object)
throws HibernateException {
MyEntity entity = (MyEntity)object;
if(entity.getId()==null){
Connection con = session.connection();
// retrieve next sequence val from database for example
return nextSeqValue;
}
}
}
然后在实体的id字段上添加适当的注释:
@Id
@GenericGenerator(name="myCustomGen", strategy="com.example.MyEntityGenerator")
@GeneratedValue(generator="myCustomGen")