我试图在以下方面实现惰性负载。
用户.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>

雇员.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>

首先,我基于用户名获取用户对象。现在我正试图加载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中映射一对一,它应该引用孩子的user_id

最佳答案

前一阵子想出了解决办法,但忘了贴出来。
上面的问题是coz,默认情况下,对于父主键为子主键的子表,将实现一对一映射。因此,如果我们要消除这个默认属性并使用一对一和多对一(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 模式下一对一和多对一(唯一= true)获取时发生奇怪的行为,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/28794204/

10-11 05:02