gpt4 book ai didi

java - Spring Data JPA同时保存两个实体,列 "user_id"中为空值

转载 作者:行者123 更新时间:2023-12-02 01:38:10 24 4
gpt4 key购买 nike

我的应用程序中有用户,并且用户有工作详细信息,我使用一种方法来设置用户/工作详细信息数据,然后添加新用户或修改现有用户。

这是设置用户/工作数据的方法:

public WorkDetail setWorkerData(PatchWorkerRequest request, User user, WorkDetail workDetail) {

if (request.getName() != null) {
user.setName(request.getName());
}

if (request.getIdCode() != null) {
user.setIdCode(request.getIdCode());
}

if (request.getEmail() != null) {
user.setEmail(request.getEmail());
}

if (request.getPhone() != null) {
user.setPhone(request.getPhone());
}

if (request.getAddress() != null) {
user.setAddress(request.getAddress());
}

if (request.getSignatureLevel() != null) {
user.setSignatureLevel(request.getSignatureLevel());
}

if (request.getAltContactRelation() != null) {
user.setAltContactRelation(request.getAltContactRelation());
}

if (request.getAltContactPhone() != null) {
user.setAltContactPhone(request.getAltContactPhone());
}

if (request.getRoles() != null) {
user.setRoles(request.getRoles());
}

if (request.getStatus() != null) {
user.setStatus(request.getStatus());
}

// Work details

if (request.getJobRelation() != null) {
workDetail.setJobRelation(request.getJobRelation());
}

if (request.getSalary() != null) {
workDetail.setSalary(request.getSalary());
}

if (request.getDistricts() != null) {
workDetail.setDistricts(request.getDistricts());
}

if (request.getCompetences() != null) {
workDetail.setCompetences(request.getCompetences());
}

workDetail.setUser(user);
user.setWorkDetail(workDetail);

return workDetailRepository.save(workDetail);
}

现在,使用以下代码修改现有工作人员可以正常工作:

public WorkDetail modifyWorker(Long workerId, PatchWorkerRequest request) {
WorkDetail workDetail = this.getWorkDetailById(workerId);
User user = userService.getUserById(workDetail.getUser().getId());
return setWorkerData(request, user, workDetail);
}

但是,当我尝试创建新用户/工作人员时,我收到一条错误:““user_id”列中的空值违反了非空约束””。我认为这是因为 workDetail 和用户没有正确连接。

这是创建新worker的方法:

public WorkDetail createWorker(PatchWorkerRequest request) {
WorkDetail workDetail = new WorkDetail();
User user = new User();
String generatedPassword = userService.generatePassword(8);
user.setPassword(passwordEncoder.encode(generatedPassword));
emailService.sendMail("SYDA", new String[]{request.getEmail()},
"Project SYDA",
"New password: " + generatedPassword + ".);
return setWorkerData(request, user, workDetail);
}

此外,有什么方法可以在保存用户后发送电子邮件,以便在发生错误时不会发送电子邮件?

实体:

用户:

@Entity
@Data
@NoArgsConstructor
@TypeDefs({
@TypeDef(name = "pgsql_enum", typeClass = PostgreSQLEnumType.class)
})
@Table(name = "user_acc")
public class User implements Serializable {

@Id
@Column(unique = true, nullable = false, columnDefinition = "serial")
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;

@Column(name = "name", nullable = false)
private String name;

@Column(name = "id_code")
private BigInteger idCode;

@Column(name = "email", nullable = false)
private String email;

@Column(name = "address")
private String address;

@Column(name = "phone")
private BigInteger phone;

@Column(name = "alt_contact_relation")
private String altContactRelation;

@Column(name = "alt_contact_phone")
private BigInteger altContactPhone;

@Column(name = "password", nullable = false)
@JsonIgnore
private String password;

@JsonIgnore
@Column(name = "create_time", nullable = false, updatable = false)
private Date createTime = new Date();

@JsonIgnore
@Column(name = "update_time", nullable = false)
private Date updateTime = new Date();

@Column(name = "status", nullable = false, columnDefinition = "active_status")
@Enumerated(EnumType.STRING)
@Type(type = "pgsql_enum")
private UserStatus status;

@OneToOne
@PrimaryKeyJoinColumn
@JsonIgnore
private WorkDetail workDetail;

@OneToMany(mappedBy = "user")
private List<UserFile> userFiles = new ArrayList<>();

@ManyToOne
@JoinColumn(name = "signature_level_id")
private SignatureLevel signatureLevel;

@ManyToMany(fetch = FetchType.EAGER, targetEntity = UserRole.class)
@JoinTable(name = "user_has_user_role",
joinColumns = { @JoinColumn(name = "user_id", referencedColumnName = "id")},
inverseJoinColumns = { @JoinColumn(name = "user_role_id", referencedColumnName = "id")}
)
private Set<UserRole> roles = new HashSet<>();

@ManyToMany(fetch = FetchType.EAGER, targetEntity = Mechanism.class)
@JoinTable(name = "user_has_mechanism",
joinColumns = { @JoinColumn(name = "user_id", referencedColumnName = "id")},
inverseJoinColumns = { @JoinColumn(name = "mechanism_id", referencedColumnName = "id")}
)
private Set<Mechanism> mechanisms = new HashSet<>();

@ManyToMany(fetch = FetchType.EAGER, targetEntity = Service.class)
@JoinTable(name = "user_has_service",
joinColumns = { @JoinColumn(name = "user_id", referencedColumnName = "id")},
inverseJoinColumns = { @JoinColumn(name = "service_id", referencedColumnName = "id")}
)
private Set<Service> services = new HashSet<>();

@PreUpdate
@PrePersist
public void onCreateOnUpdate() {
updateTime = new Date();
}

public enum UserStatus {
active, temporarily_inactive, inactive
}
}

工作详情:

@Entity
@Data
@Table(name = "work_detail")
public class WorkDetail {

@Id
@Column(unique = true, nullable = false, columnDefinition = "serial")
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;

@Column(name = "salary")
private float salary;

@OneToOne(mappedBy = "workDetail",fetch = FetchType.LAZY, optional = true)
@PrimaryKeyJoinColumn
private User user;

@Column(name = "create_time", nullable = false, updatable = false)
@JsonIgnore
private Date createTime = new Date();

@Column(name = "update_time", nullable = false)
@JsonIgnore
private Date updateTime = new Date();

@OneToMany(cascade = CascadeType.ALL, mappedBy = "workDetail")
private List<UserLeave> userLeaves = new ArrayList<>();

@ManyToOne
@JoinColumn(name = "job_relation_id")
private JobRelation jobRelation;

@ManyToMany(fetch = FetchType.EAGER, targetEntity = District.class)
@JoinTable(name = "work_detail_has_district",
joinColumns = { @JoinColumn(name = "work_detail_id", referencedColumnName = "id")},
inverseJoinColumns = { @JoinColumn(name = "district_id", referencedColumnName = "id")}
)
private Set<District> districts = new HashSet<>();

@ManyToMany(fetch = FetchType.EAGER, targetEntity = Competence.class)
@JoinTable(name = "work_detail_has_competence",
joinColumns = { @JoinColumn(name = "work_detail_id", referencedColumnName = "id")},
inverseJoinColumns = { @JoinColumn(name = "competence_id", referencedColumnName = "id")}
)
private Set<Competence> competences = new HashSet<>();

@PreUpdate
@PrePersist
public void onCreateOnUpdate() {
updateTime = new Date();
}
}

数据库表:

-----------------------
-- User table
-----------------------

CREATE TABLE IF NOT EXISTS user_acc (
id SERIAL NOT NULL PRIMARY KEY,
name text NOT NULL,
id_code numeric NOT NULL,
email text NOT NULL UNIQUE,
address text NULL,
alt_contact_relation text NULL,
alt_contact_phone numeric NULL,
signature_level_id integer NULL,
username text NOT NULL,
password text NOT NULL,
create_time TIMESTAMP without TIME ZONE DEFAULT now() NOT NULL,
update_time TIMESTAMP without TIME ZONE DEFAULT now() NOT NULL,
status active_status NOT NULL DEFAULT 'active',
CONSTRAINT FK_user_signature_level FOREIGN KEY (signature_level_id) REFERENCES signature_level (id)
ON DELETE NO ACTION ON UPDATE NO ACTION
);

-----------------------
-- User: work detail table
-----------------------

CREATE TABLE IF NOT EXISTS work_detail (
id SERIAL NOT NULL PRIMARY KEY,
salary decimal NULL,
job_relation_id integer NOT NULL,
user_id integer NOT NULL,
create_time TIMESTAMP without TIME ZONE DEFAULT now() NOT NULL,
update_time TIMESTAMP without TIME ZONE DEFAULT now() NOT NULL,
CONSTRAINT FK_work_detail_user FOREIGN KEY (user_id) REFERENCES user_acc (id)
ON DELETE NO ACTION ON UPDATE NO ACTION,
CONSTRAINT fk_work_details_job_relations1 FOREIGN KEY (job_relation_id)
REFERENCES job_relation (id)
ON DELETE NO ACTION
ON UPDATE NO ACTION);

最佳答案

您需要先保存用户,然后再将其添加到workDetail。新的 User 对象没有 id,这就是您收到该异常的原因。像这样的事情:

public WorkDetail createWorker(PatchWorkerRequest request) {
WorkDetail workDetail = new WorkDetail();
User user = new User();
String generatedPassword = userService.generatePassword(8);
user.setPassword(passwordEncoder.encode(generatedPassword));
user = userRepository.save(user);
emailService.sendMail("SYDA", new String[]{request.getEmail()},
"Project SYDA",
"New password: " + generatedPassword + ".);
return setWorkerData(request, user, workDetail);
}

或者您可以在 setWorkerData 方法中添加 saveUser 调用。

...
if (request.getStatus() != null) {
user.setStatus(request.getStatus());
}
user = userRepository.save(user);
...

关于java - Spring Data JPA同时保存两个实体,列 "user_id"中为空值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54881081/

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