JPA:覆盖自动生成的 ID

2022-09-04 01:24:50

我在员工类中有以下定义

@Id
@GeneratedValue(strategy = GenerationType.AUTO)
@Column(name = "employee_id")
private Integer employeeId;

现在,我想导入具有现有员工 ID 的现有员工。即使我在保存之前设置了员工 ID,也会忽略分配的 ID 并存储自动递增的 ID。我们如何覆盖它?

我对复合键有类似的问题,这里已经解释过了


答案 1

我编写了自己的生成器来解决这个问题。

public class UseExistingIdOtherwiseGenerateUsingIdentity extends IdentityGenerator {

    @Override
    public Serializable generate(SharedSessionContractImplementor session, Object object) throws HibernateException {
        Serializable id = session.getEntityPersister(null, object).getClassMetadata().getIdentifier(object, session);
        return id != null ? id : super.generate(session, object);
    }
}

并像这样使用它:(替换包名称)

@Id
@GenericGenerator(name = "UseExistingIdOtherwiseGenerateUsingIdentity", strategy = "{package}.UseExistingIdOtherwiseGenerateUsingIdentity")
@GeneratedValue(generator = "UseExistingIdOtherwiseGenerateUsingIdentity")
@Column(unique = true, nullable = false)
protected Integer id;

答案 2

您无法覆盖它。首先,JPA没有提供这样做的方法。第二个问题是GenerationType.AUTO可以生成这样的列类型,该列类型不会通过SQL语句接受用户分配的值。

手动执行数据导入,不要尝试将应用程序本身用作导入工具。


推荐