级联在保存数据时不起作用

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 在保存时不起作用

保存的首选项在重新启动时不起作用

使用 Django 时,save() 函数在使用模型表单时不起作用

sql级联更新和级联删除不起作用

为啥 random.seed() 在生成数据集时不起作用?

ckeditor插入或更新在第一次尝试时不起作用