【问题标题】:Hibernate OneToOne using Spring and JSP使用 Spring 和 JSP 休眠 OneToOne
【发布时间】:2012-08-11 23:21:39
【问题描述】:

我有一个问题要问:

我必须表 user 和 user_login 通过 user.id -> user_login.user_id 加入 OneToOne。

问题是当我执行 .updateObject(user) 时,我执行了 2 个查询:

Hibernate:插入用户(创建、修改、电子邮件、名字、 last_name) 值 (?, ?, ?, ?, ?) Hibernate: 插入 user_login (created, modified, password, user_id) 值 (?, ?, ?, ?) [2012-08-15 12:15:04,192] [错误] [http-bio-8080-exec-1] SqlExceptionHelper [144]: 列“user_id”不能为空

并且看起来 2 个对象之间没有引用。如果进入实体用户,方法 setUserLogin 我添加行 userLogin.setUser(this);它的工作,但老实说,我不觉得这种方式优雅。我在实体配置中有什么遗漏的吗 也许这不会自动执行?

谢谢

这是我的实体

@Entity
@NamedQueries({ @NamedQuery(name = "user.list", query = "select u from User u") })
public class User implements java.io.Serializable {

    @Column(name = "first_name", nullable = true)
    private String firstName;   

    @OneToOne(mappedBy = "user", cascade = CascadeType.ALL, fetch = FetchType.LAZY)
    @JoinColumn(name="user_id", nullable=false)
    private UserLogin userLogin;

    public String getFirstName() {
        return firstName;
    }

    public void setFirstName(String firstName) {
        this.firstName = firstName;
    }


    public UserLogin getUserLogin() {
        return userLogin;
    }

    public void setUserLogin(UserLogin userLogin) {
        this.userLogin = userLogin;
        //userLogin.setUser(this); THIS IS THE LINE THAT FIXES IT, BUT I DONT FIND THIS WAY ELEGANT
    }

}


@Entity
@Table(name="user_login")
public class UserLogin implements java.io.Serializable {

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


    @OneToOne(optional = false, fetch = FetchType.LAZY) 
  private User user;


    public String getPassword() {
        return password;
    }

    public void setPassword(String password) {
        this.password = password;
    }

    public User getUser() {
        return user;
    }

    public void setUser(User user) {
        this.user = user;
    }   

}

JSP 文件:

<%@ taglib uri="http://www.springframework.org/tags/form" prefix="form"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/functions" prefix="fn"%>
<html>
<head>
<title>Registration Page</title>
</head>
<body>
    <form:form action="/test" commandName="user">
        <tr>
            <td>User Name :</td>
            <td><form:input path="firstName" /></td>
        </tr>
        <tr>
            <td>Password :</td>
            <td><form:input path="userLogin.password" /></td>
        </tr>
        <tr>
            <td colspan="2"><input type="submit" value="Register"></td>
        </tr>
        </table>
    </form:form>
</body>
</html>

弹簧控制器:

@Controller(value = "/")
public class Test { 

  @Autowired
    UserServiceImpl userServiceImpl;

  @RequestMapping(method = RequestMethod.GET, value = "/test")
  public void test(ModelMap model) {

    model.addAttribute("user", new User());

  }

  @RequestMapping(method = RequestMethod.POST, value = "/test")
  public void test(User user) {

    userServiceImpl.update(user);    

  }
} 

【问题讨论】:

  • 您的实体的代码是否完整?
  • 是的,我只是没有粘贴导入。当然我也会添加更多字段

标签: spring hibernate jsp


【解决方案1】:

像往常一样,双向关系确实有拥有方。关系的拥有方是被 mappedBy 引用的属性。在您的情况下,UserLogin 实体中的属性 user 是拥有方。

当关系被持久化到数据库时,只咨询拥有方。这意味着,您必须为 user 属性设置值才能持续存在。为了使内存中的实体图也保持一致,应该设置关系的两侧。

在 JPA 2.0 规范中,这是用以下词语来说明的:

托管实体之间的双向关系将保持不变 基于关系拥有方持有的引用。它是 开发人员有责任保留内存中的引用 在拥有方和持有在相反方的人一致 当他们改变时彼此。

【讨论】:

    猜你喜欢
    • 2012-07-30
    • 1970-01-01
    • 2011-02-25
    • 1970-01-01
    • 2011-02-13
    • 2011-09-19
    • 1970-01-01
    • 2021-06-25
    • 2012-10-14
    相关资源
    最近更新 更多