我在 Employee 类中有以下定义
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
@Column(name = "employee_id")
private Integer employeeId;
现在我想用现有员工 ID 导入现有员工。即使我在保存之前设置了员工 ID,分配的 ID 也会被忽略并存储自动递增的 ID。我们如何覆盖它?
我对复合键有类似的问题,这里已经解释过
我编写了自己的生成器来解决这个问题。
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;
你不能覆盖它。首先,JPA 没有提供这样做的方法。第二个问题是 GenerationType.AUTO 可以生成这样的列类型,它不会通过 SQL 语句接受用户分配的值。
手动执行数据导入,不要尝试将应用程序本身用作导入工具。
在这种情况下,您必须覆盖 getEmployeeId() 方法并在此方法上使用 Annotation,JPA 对类中的所有字段使用 getter 方法,您必须在 getter 方法上移动其他 Annotation
在这种情况下,最好有一个 @MappedSuperclass
@MappedSuperclass
public AbstractEmployee {
// declare all properties, getters, setters except for the id
}
@Entity
@Table(name="EMPLOYEE")
public class Employee extends AbstractEmployee {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
@Column(name = "employee_id")
private Integer employeeId;
...
}
@Entity
@Table(name="EMPLOYEE")
public class EmployeeWithAssignedId extends AbstractEmployee {
@Id
@Column(name = "employee_id")
private Integer employeeId;
...
}
因此,当您要手动分配 ID 时,请使用第二类。我没有对此进行测试,但我相信它应该适用于您的情况。我不相信 JPA 中有任何规则说两个类不能具有相同的表名:)