级联在保存数据时不起作用
Posted
技术标签:
【中文标题】级联在保存数据时不起作用【英文标题】:cascade not working while saving the data 【发布时间】:2014-06-27 13:21:48 【问题描述】:我有一对一的映射关系。
用户.java
public class User
@Id
@SequenceGenerator(name = "userID", sequenceName = "userID")
@GeneratedValue(strategy = GenerationType.AUTO, generator = "userID")
@Column(name = "id")
private Long id;
private String firstName;
private String lastName;
@Column(unique = true)
private String username;
private String password;
@OneToOne(mappedBy = "user", cascade = CascadeType.ALL, fetch = FetchType.LAZY)
@JoinColumn(name = "id")
private Role role;
public Long getId()
return id;
public void setId(Long id)
this.id = id;
public String getFirstName()
return firstName;
public void setFirstName(String firstName)
this.firstName = firstName;
public String getLastName()
return lastName;
public void setLastName(String lastName)
this.lastName = lastName;
public String getUsername()
return username;
public void setUsername(String username)
this.username = username;
public String getPassword()
return password;
public void setPassword(String password)
this.password = password;
public Role getRole()
return role;
public void setRole(Role role)
this.role = role;
@Override
public String toString()
return "User [id=" + id + ", firstName=" + firstName + ", lastName="
+ lastName + ", username=" + username + ", password="
+ password + ", role=" + role + "]";
Roles.java
public class Role
@Id
@SequenceGenerator(name = "userID", sequenceName = "userID")
@GeneratedValue(strategy = GenerationType.AUTO, generator = "userID")
@Column(name = "roleId")
private Long roleId;
@OneToOne
private User user;
private Integer role;
public Long getId()
return roleId;
public void setId(Long id)
this.roleId = id;
public User getUser()
return user;
public void setUser(User user)
this.user = user;
public Integer getRole()
return role;
public void setRole(Integer role)
this.role = role;
我正在保存数据
public Long create(User user)
Long userID = super.save(user);
return userID;
当我尝试保存用户实体时,我看到数据保存如下。
用户表:
id firstName lastName usrename password
1 hello hello hello hello
角色表:
roleId role user_id
1 1 NULL
你能告诉我用户表没有相互关联吗?
我需要 user_id 为 1 而不是 NULL。
这里 user 表的 id 没有映射到表 Role 的 user_id。
【问题讨论】:
如果是拥有角色的用户,则将 mappedBy 放在角色实体上并将其从用户中删除。 【参考方案1】:角色是关联的所有者,用户的@OneToOne角色根本不需要@JoinColumn:
@Id
@SequenceGenerator(name = "userID", sequenceName = "userID")
@GeneratedValue(strategy = GenerationType.AUTO, generator = "userID")
@Column(name = "id")
private Long id;
@OneToOne(mappedBy = "user", cascade = CascadeType.ALL, fetch = FetchType.LAZY)
private Role role;
保存用户时还需要设置关联的两边:
user.setRole(role);
role.setUser(user);
userDao.create(user);
【讨论】:
我能知道为什么我必须设置双方关联。我需要用户作为所有者,角色作为孩子。如果@OnetoOne rolw 不需要@JoinColumn? 每一个双向关联must set both sides. 我需要一种单向的添加方式。如果我添加用户,它也应该保存特定用户的角色。是否有可能拥有这个。很抱歉问这些类型的问题。我知道我在问愚蠢的问题。你能帮我实现单向级联关联吗?以上是关于级联在保存数据时不起作用的主要内容,如果未能解决你的问题,请参考以下文章
核心数据:后台更新 NSManagedObjectContext 在保存时不起作用