gpt4 book ai didi

java - 在 hibernate 中一对一和多对一(unique = true)获取的奇怪行为

转载 作者:行者123 更新时间:2023-11-29 03:32:20 28 4
gpt4 key购买 nike

我正在尝试在以下方面实现延迟加载。

用户.java

public class User {

private int id;
private String userName;
private String password;
private Employee employee;

//getter and setters

}

用户.hbm.xml

<hibernate-mapping>
<class name="com.site.dto.User" table="user">
<id name="id" type="java.lang.Integer">
<column name="id" />
<generator class="identity" />
</id>
<property name="userName" type="string" update="false">
<column name="user_name" length="50" not-null="true" unique="true" />
</property>
<property name="password" type="string">
<column name="password" length="50" not-null="true" unique="true" />
</property>
<one-to-one name="employee" class="com.site.dto.Employee" fetch="select" cascade="save-update" />
</class>
</hibernate-mapping>

员工.java

public class Employee implements Serializable{

private int id;
private String name;
private String email;
private User user;

// getter and setters

}

员工.hbm.xml

<hibernate-mapping>
<class name="com.site.dto.Employee" table="employee">
<id name="id" type="java.lang.Integer">
<column name="id" />
<generator class="identity" />
</id>
<property name="name" type="string">
<column name="name" length="50" not-null="true" unique="true" />
</property>
<property name="email" type="string" update="false">
<column name="email" length="50" not-null="true" unique="true" />
</property>

// enforcing many-to-one to one-to-one by putting unique="true"
<many-to-one name="user" column="user_id" class="com.site.dto.User" unique="true" not-null="true" fetch="select" cascade="save-update" />
</class>
</hibernate-mapping>

首先,我根据用户名获取用户对象。现在我正在尝试加载 employee 对象,它给我空指针异常。因此,在进行了一些调试之后,它似乎使用了带有错误 where 子句的 select 语句。这是 hibernate 调试

select employee0_.id as id1_1_0_, employee0_.name as name2_1_0_, employee0_.email as email3_1_0_,employee0_.user_id as user_id25_1_0_, from employee employee0_ where employee0_.id=?

为什么 where 子句基于 employee.id 而不是 employee.user.id ?我认为这是由于一对一映射在 hbm.xml 配置中如何工作的原因,其中一对一将链接到子表的主键 id 而不是 user_id 。我通过使用 unique="true" 强制员工中的多对一到一对一。我可以通过定义 @Join-column 在 Hibernate 注释的一对一中获取员工,但我无法弄清楚如何映射 hbm.xml 中的一对一应该引用 child 的 user_id

最佳答案

前一段时间想出了解决方案,但忘记发布了。

上面的问题是因为,默认情况下,对于子表,父表的主键作为子表的主键,将实现一对一的映射。因此,如果我们要消除该默认属性并使用一对一和多对一 (unique=true),我们应该定义 property-ref

我在 User.hbm.xml 中的一对一映射中添加了 property-ref,现在它工作正常。

<one-to-one name="employee" property-ref="user" class="com.site.dto.Employee" fetch="select" cascade="save-update" />

关于java - 在 hibernate 中一对一和多对一(unique = true)获取的奇怪行为,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28794204/

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