@Transactional
@Override
public void saveEmployee(EmployeeTable employeeToSave)
{
employeeDao.saveOrUpdate(employeeToSave);
}
受雇的
package de.adesso.kkBonus.model;
import com.google.common.collect.Lists;
import de.adesso.kkBonus.enums.*;
import de.adesso.kkBonus.util.BillConstants;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.EqualsAndHashCode;
import lombok.NoArgsConstructor;
import lombok.ToString;
import org.hibernate.annotations.Cascade;
import org.springframework.beans.BeanUtils;
import javax.persistence.*;
import java.util.ArrayList;
import java.util.Date;
import java.util.LinkedList;
import java.util.List;
@Data
@AllArgsConstructor
@NoArgsConstructor
@Entity
@Table(name = "employee_table")
@EqualsAndHashCode(of = {"id"})
@ToString(of = "id")
public class EmployeeTable {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "id")
private Long id;
@Column(name = "deleted")
private boolean deleted;
@Column(name = "name", length = 200, nullable = false)
private String name;
@Column(name = "tckn", length = 11)
private String tckn;
@Column(name = "social_security_number")
private String socialSecurityNumber;
@Column(name = "address", length = 1000)
private String address;
@Column(name = "birthday")
private Date birthday;
@Column(name = "lob")
@Enumerated(EnumType.STRING)
private LobEnum lob;
@Column(name = "on_boarding_date", nullable = false)
private Date onBoardingDate;
@Column(name = "off_boarding_date")
private Date offBoardingDate;
@Column(name = "off_boarding_reason")
private String offBoardingReason;
@Column(name = "manager")
private boolean manager;
@Column(name = "created_by", length = 200, nullable = false)
private String createdBy;
@Column(name = "creation_date")
private Date creationDate;
@Column(name = "modified_by", length = 200, nullable = false)
private String modifiedBy;
@Column(name = "modified_date", updatable = false)
private Date modifiedDate;
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "manager_fk", referencedColumnName = "id")
private EmployeeTable director;
@Column(name = "mail", length = 50, nullable = false)
private String mail;
@Column(name = "certificate", length = 1000)
private String certificate;
@Column(name = "billable")
private Boolean billable;
@Column(name = "outsource")
private Boolean outsource;
@Column(name = "location", length = 255)
private String location;
@Column(name = "gender")
@Enumerated(EnumType.STRING)
private GenderEnum gender;
@Column(name = "blood_type")
@Enumerated(EnumType.STRING)
private BloodTypeEnum bloodType;
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "buddy", nullable = true)
private EmployeeTable buddy;
@Column(name = "contract_type")
@Enumerated(EnumType.STRING)
private ContractTypeEnum contractType;
@Column(name = "competence_center")
@Enumerated(EnumType.STRING)
private CompetenceCenterEnum competenceCenter;
@Column(name = "position")
@Enumerated(EnumType.STRING)
private PositionEnum position;
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "hrbp", referencedColumnName = "id")
private EmployeeTable hrbp;
@Column(name = "education_status")
@Enumerated(EnumType.STRING)
private EducationStatusEnum educationStatus;
@Column(name = "military_status")
@Enumerated(EnumType.STRING)
private MilitaryStatusEnum militaryStatus;
@Column(name = "military_exempt_reason", length = 500)
private String militaryExemptReason;
@Column(name = "military_postponement_date")
private Date militaryPostponementDate;
@Column(name = "personal_phone_number", length = 20)
private String personalPhoneNumber;
@Column(name = "work_phone_number", length = 20)
private String workPhoneNumber;
@Column(name = "private_email", length = 50)
private String privateEmail;
@Column(name = "emergency_person_name", length = 120)
private String emergencyPersonName;
@Column(name = "emergency_person_phone_number", length = 11)
private String emergencyPersonPhoneNumber;
//Sicil No
@Column(name = "registry_number", length = 50)
private String registryNumber;
@Column(name = "continuity", length = 3)
private Integer continuity;
@Column(name = "iban", length = 50)
private String iban;
@OneToOne(cascade = CascadeType.ALL)
@JoinColumn(name = "graduation_id")
private GraduationTable graduation;
@OneToOne(cascade = CascadeType.ALL, mappedBy = "employeeTable", orphanRemoval = true, fetch = FetchType.LAZY)
private UserTable userTable;
@OneToMany(cascade = CascadeType.ALL, mappedBy = "employee", orphanRemoval = false, fetch = FetchType.LAZY)
private List<InventoryTable> inventoryTables;
@OneToMany(cascade = CascadeType.ALL, mappedBy = "employee", orphanRemoval = true, fetch = FetchType.LAZY)
private List<ResearchAndDevelopmentDetailsTable> researchAndDevelopmentDetailsTables;
@OneToMany(cascade = CascadeType.ALL, mappedBy = "employeeTable", orphanRemoval = true, fetch = FetchType.LAZY)
private List<EmployeeUploadTable> employeeUploadTables = Lists.newArrayList();
@Lob
@Column(name = "image", columnDefinition = "MEDIUMBLOB")
private String image;
@Transient
public boolean isMale() {
return gender.equals(GenderEnum.MALE);
}
public EmployeeTable createCopy() {
EmployeeTable target = new EmployeeTable();
BeanUtils.copyProperties(this, target);
if (this.getGraduation() != null) {
target.setGraduation(this.getGraduation().createCopy());
}
List listDocuments = new LinkedList();
if (employeeUploadTables != null) {
for (EmployeeUploadTable employeeUploadTable : employeeUploadTables) {
listDocuments.add(employeeUploadTable.createCopy());
}
target.getEmployeeUploadTables().clear();
target.getEmployeeUploadTables().addAll(listDocuments);
}
return target;
}
public boolean isOffBoarded() {
return offBoardingDate != null;
}
public EmployeeUploadTable getResidenceCertificate() {
if (employeeUploadTables != null) {
for (EmployeeUploadTable employeeUploadTable : employeeUploadTables) {
if (DocumentTypeEnum.RESIDENCE_CERTIFICATE.equals(employeeUploadTable.getContentType())) {
return employeeUploadTable;
}
}
}
return null;
}
public EmployeeUploadTable getBirthCertificate() {
if (employeeUploadTables != null) {
for (EmployeeUploadTable employeeUploadTable : employeeUploadTables) {
if (DocumentTypeEnum.BIRTH_CERTIFICATE.equals(employeeUploadTable.getContentType())) {
return employeeUploadTable;
}
}
}
return null;
}
public EmployeeUploadTable getDiploma() {
if (employeeUploadTables != null) {
for (EmployeeUploadTable employeeUploadTable : employeeUploadTables) {
if (DocumentTypeEnum.DIPLOMA.equals(employeeUploadTable.getContentType())) {
return employeeUploadTable;
}
}
}
return null;
}
public EmployeeUploadTable getMilitaryStatusCertificate() {
if (employeeUploadTables != null) {
for (EmployeeUploadTable employeeUploadTable : employeeUploadTables) {
if (DocumentTypeEnum.MILITARY_STATUS_CERTIFICATE.equals(employeeUploadTable.getContentType())) {
return employeeUploadTable;
}
}
}
return null;
}
public EmployeeUploadTable getHealthReport() {
if (employeeUploadTables != null) {
for (EmployeeUploadTable employeeUploadTable : employeeUploadTables) {
if (DocumentTypeEnum.HEALTH_REPORT.equals(employeeUploadTable.getContentType())) {
return employeeUploadTable;
}
}
}
return null;
}
public EmployeeUploadTable getWorkCertificate() {
if (employeeUploadTables != null) {
for (EmployeeUploadTable employeeUploadTable : employeeUploadTables) {
if (DocumentTypeEnum.WORK_CERTIFICATE.equals(employeeUploadTable.getContentType())) {
return employeeUploadTable;
}
}
}
return null;
}
public EmployeeUploadTable getPayroll() {
if (employeeUploadTables != null) {
for (EmployeeUploadTable employeeUploadTable : employeeUploadTables) {
if (DocumentTypeEnum.PAYROLL.equals(employeeUploadTable.getContentType())) {
return employeeUploadTable;
}
}
}
return null;
}
public EmployeeUploadTable getCriminalRecord() {
if (employeeUploadTables != null) {
for (EmployeeUploadTable employeeUploadTable : employeeUploadTables) {
if (DocumentTypeEnum.CRIMINAL_RECORD.equals(employeeUploadTable.getContentType())) {
return employeeUploadTable;
}
}
}
return null;
}
public void addEmployeeUpdateTable(List<EmployeeUploadTable> employeeUploadTableList) {
for (EmployeeUploadTable employeeUploadTable : employeeUploadTableList) {
employeeUploadTable.setEmployeeTable(this);
this.getEmployeeUploadTables().add(employeeUploadTable);
}
}
public Boolean isAllDocumentsUploaded(){
if(this.getBirthCertificate() == null || this.getResidenceCertificate() == null || this.getDiploma() == null
|| this.getMilitaryStatusCertificate() == null || this.getHealthReport() == null
|| this.getWorkCertificate() == null || this.getPayroll() == null || this.getCriminalRecord() == null){
return Boolean.FALSE;
}
return Boolean.TRUE;
}
}
Emploadable
package de.adesso.kkBonus.model;
import de.adesso.kkBonus.enums.DocumentTypeEnum;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.ToString;
import org.hibernate.annotations.Cascade;
import org.springframework.beans.BeanUtils;
import javax.persistence.*;
import java.util.Date;
@Data
@AllArgsConstructor
@NoArgsConstructor
@Entity
@Table(name = "employee_upload_table")
@ToString(of = "id")
public class EmployeeUploadTable {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "id")
private Long id;
@ManyToOne(cascade = CascadeType.PERSIST)
@JoinColumn(name = "employee_fk")
private EmployeeTable employeeTable;
@Column(name = "name")
private String name;
@Column(name = "content_type")
@Enumerated(EnumType.STRING)
private DocumentTypeEnum contentType;
@Column(name = "content")
private byte[] content;
@Transient
public EmployeeUploadTable createCopy() {
EmployeeUploadTable target = new EmployeeUploadTable();
BeanUtils.copyProperties(this, target);
return target;
}
public EmployeeUploadTable(DocumentTypeEnum documentTypeEnum) {
this.setContentType(documentTypeEnum);
}
}
当将用于持久化实体(JPA专有)的操作的CascadeType.persist
与using saveorupdate混合使用时,就会产生这个问题。
有两种选择:
将以下CascadeType添加到集合字段:
@org.hibernate.annotations.Cascade(org.hibernate.annotations.CascadeType.SAVE_UPDATE)
employeeDao.persist(employeeToSave);
我有一个数据库,有两个表Batchstatistics和ReconProcessDateTracker。我想了解他们之间的关系。我使用以下模型类使用hibernate实现这一点: } } 当我试图保存它时,我得到的错误对象引用了一个未保存的瞬态实例——在刷新之前保存瞬态实例:com。美国药典。实体TBLBatch统计
错误: 我还尝试了,但是 病因是什么?显然,我设置了nullable=true(在数据库中也是如此),尽管我有这个错误。有什么想法吗?
我正在使用Seam Framework。我有2个实体: Request.java 和请求事件.java 当我进行此交易时: 我得到了这个错误:
我有两个例子。一个是项目,一个是模块。< code >一对多关系。 我将模块设置到项目中。然后使用。第一次,因为数据库中没有记录,所以项目和模块可以保存到数据库中。然而,第二次,因为我不需要创建新项目,我只创建新模块,然后将模块设置回项目。 发生异常。 对象引用未保存的瞬态实例 - 在刷新之前保存瞬态实例。 有什么办法可以解决这个问题吗谢谢
上图显示了表之间的关系。 AddressType表包含静态值,如mailing、home、work等。 在AddressTypeRel模型类中,我有一个带有多对一注释的AddressType对象
我正在尝试执行此查询: 但是我有这个例外: org . hibernate . transientobjectexception:对象引用未保存的瞬态实例-刷新前保存瞬态实例:com . GIS app . spring boot . back end . API rest . models . entity . polygonentity 这是多边形实体: 我在这里阅读了一个可能的解决方案,但观