![](/img/trans.png)
[英]Hibernate One-to-One and Many-to-One relationship strange behaviour after saving entities
[英]Strange behavior on one-to-one and many-to-one (unique=true) fetching in hibernate
我正在尝试在以下方面实现延迟加载。
User.java
public class User {
private int id;
private String userName;
private String password;
private Employee employee;
//getter and setters
}
User.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>
Employee.java
public class Employee implements Serializable{
private int id;
private String name;
private String email;
private User user;
// getter and setters
}
Employee.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>
首先,我要根据用户名获取用户对象。 现在,我正在尝试加载雇员对象,这给了我空指针异常。 因此,在进行了一些调试之后,似乎正在使用带有错误where子句的select语句。 这是休眠调试
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中一对一地映射该子对象的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" />
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.