gpt4 book ai didi

java - 所有实体的主键都会递增

转载 作者:行者123 更新时间:2023-12-01 13:58:11 25 4
gpt4 key购买 nike

我正在编写简单的 SE 应用程序,对两个实体进行 CRUD 操作。我注意到两个实体的主键都是自动递增的。当我保存 FirstEntity 的新对象时,它得到 ID = 1,这很好,但是,然后我保存 SecondEntity ,它的 ID 是 2,但应该是 1,因为没有其他实体类型为SecondEntity。出现这种情况的原因是什么?

第一个实体:

@Entity
@NamedQueries( value = {
@NamedQuery( name = "Employee.findAll", query = "SELECT e FROM Employee e")
})
public class Employee extends AbstractModel<Long, Employee>{

@Id
@GeneratedValue( strategy = GenerationType.AUTO )
private Long id;

@Basic
@Column( name = "FIRST_NAME" )
private String firstName;
@Basic
@Column( name = "LAST_NAME" )
private String lastName;
@Basic
@Column( name = "ACCOUNT_NUMBER" )
private String accountNumber;
@Column( name = "BIRTH_DATE" )
@Temporal(TemporalType.DATE)
private Date birthDate;

@ManyToMany(cascade = CascadeType.REMOVE)
@JoinTable( name = "EMP_TASK", joinColumns = {@JoinColumn( name = "EMP_ID", referencedColumnName = "ID")},
inverseJoinColumns = {@JoinColumn( name = "TASK_ID", referencedColumnName = "ID")})
private Set<Task> tasks = new HashSet<>();
}

第二个实体:

@Entity
@NamedQueries( value = {
@NamedQuery( name = "Task.findFinished", query = "SELECT t FROM Task t where t.endDate <= :date"),
@NamedQuery( name = "Task.findActive", query = "SELECT t FROM Task t where t.startDate <= :date and :date <= t.endDate"),
@NamedQuery( name = "Task.findAll", query = "SELECT t FROM Task t")
})
public class Task extends AbstractModel<Long, Task>{

@Id
@GeneratedValue(strategy = GenerationType.AUTO)
private Long id;

@Basic
private String name;
@Column( name = "START_DATE")
@Temporal(TemporalType.DATE)
private Date startDate;
@Column( name = "END_DATE")
@Temporal(TemporalType.DATE)
private Date endDate;

@ManyToMany( mappedBy = "tasks", cascade = CascadeType.REMOVE )
private Set<Employee> employees = new HashSet<>();
}

抽象模型:

public abstract class AbstractModel<ID extends Serializable, T extends AbstractModel<ID, T>> implements Serializable {

private Class<T> modelClass;

abstract public ID getId();

/**
* Default construcot initializing class field.
*/
public AbstractModel(){
modelClass = resolveModelClass();
}

/**
* Default {2code equals(Object obj)| function for all entities
* @param obj
* object to be compared
* @return
* true if object are eqaul, false otherwise
*/
@Override
public boolean equals(Object obj){
if(!modelClass.isInstance(obj))
return false;

T other = modelClass.cast(obj);
if ((this.getId() == null && other.getId() != null) || (this.getId() != null && !this.getId().equals(other.getId()))) {
return false;
}

return true;
}

@Override
public int hashCode(){
return (getId() != null ? getId().hashCode() : 0);
}

@Override
public String toString(){
return modelClass.getName() + "[ id=" + getId() + " ]";
}

private Class<T> resolveModelClass(){
return (Class<T>) ((ParameterizedType) getClass().getGenericSuperclass()).getActualTypeArguments()[1];
}

}

持久化方法:

private static void addNewEmployee() {
Employee emp = new Employee();
// setting fields of emp

EmployeeDAO empDAO = new EmployeeDAOImpl();
emp = empDAO.create(emp);
if (emp != null) {
System.out.println("New employee with ID: " + emp.getId() + " has been saved");
} else {
System.out.println("A problem occured while trying to persist employee entity");
}
}

其中EmployeeDAO.create(Employee)使用EntityManager来持久化对象

最佳答案

您应该在 id 列上使用strategy = GenerationType.IDENTITY。 (使用表的自动增量)。

strategy = GenerationType.AUTO 将使 hibernate(或您正在使用的任何 JPA 实现)从其自己的自动增量集合中选择一个数字,该集合在所有可用表中共享。

请参阅此处了解所有选项:http://docs.oracle.com/javaee/5/api/javax/persistence/GenerationType.html

根据评论更新:

您可以尝试使用GenerationType.Sequence

@Id
@SequenceGenerator(name="sequence1", allocationSize=1, initialValue=1)
@GeneratedValue(strategy=GenerationType.SEQUENCE,generator="sequence1")
private long id;

关于java - 所有实体的主键都会递增,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19503558/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com