我有两个模型,UserModel
和RoleModel
,它们以@OneToOne
关系映射。当我更新用户详细信息时,它首先将数据插入角色表,然后将这些新角色更新为UserModel
。
UserModel.java
package com.example.demo.Model;
import javax.persistence.CascadeType;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.OneToOne;
import javax.persistence.Table;
@Entity
@Table(name="Users")
public class UserModel {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name="id")
private Integer id;
@Column(name="name")
private String name;
@Column(name="address")
private String address;
@JoinColumn(name = "role", insertable=false, nullable = false, updatable = false)
@OneToOne(cascade = CascadeType.ALL)
private RoleModel roleModel;
public UserModel() {
}
public UserModel(Integer id, String name, String address,RoleModel roleModel) {
super();
this.id = id;
this.name = name;
this.address = address;
this.roleModel = roleModel;
}
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getAddress() {
return address;
}
public void setAddress(String address) {
this.address = address;
}
public RoleModel getRoleModel() {
return roleModel;
}
public void setRoleModel(RoleModel roleModel) {
this.roleModel = roleModel;
}
}
RoleModel.java
package com.example.demo.Model;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.OneToOne;
import javax.persistence.Table;
@Entity
@Table(name="Roles")
public class RoleModel {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name="role")
private Integer role;
@Column(name="rolename")
private String roleName;
@OneToOne(mappedBy = "roleModel")
private UserModel userModel;
public RoleModel() {
}
public RoleModel(Integer role, String roleName) {
super();
this.role = role;
this.roleName = roleName;
}
public Integer getRole() {
return role;
}
public void setRole(Integer role) {
this.role = role;
}
public String getRoleName() {
return roleName;
}
public void setRoleName(String roleName) {
this.roleName = roleName;
}
}
我想同时更新UserModel
和角色,但是RoleModel
在这里插入新行,然后更新。帮我解决这个问题。告诉我确切的代码,我只应使用这些代码来更新UserModel
相关角色中的数据。
我首先建议研究弹簧关系注释如何工作。您明确表示,在RoleModel
中操作该对象时,UserModel
既不应插入也不更新,因此,即使使用所需的值修改正确的信息,也不会反映在DB端。 >
@JoinColumn(name = "role", insertable=false, nullable = false, updatable = false)
因此,如果从映射中删除
insertable=false
和updatable=false
,它将起作用(考虑到也映射了右列)。>>此外,我建议研究一些有关Spring JPA One-to-One mappings的教程。