1

我有一张表用户


CREATE TABLE "USERS" (
    "ID" NUMBER NOT NULL ,
    "LOGINNAME" VARCHAR2 (150) NOT NULL )

我有第二张表 SpecialUsers。没有 UserId 在 SpecialUsers 表中可以出现两次,并且只有一小部分用户表中的用户 id 包含在 SpecialUsers 表中。


CREATE TABLE "SPECIALUSERS" (
    "USERID" NUMBER NOT NULL,
 CONSTRAINT "PK_SPECIALUSERS" PRIMARY KEY ("USERID") )

ALTER TABLE "SPECIALUSERS" ADD CONSTRAINT "FK_SPECIALUSERS_USERID" FOREIGN KEY ("USERID") 
REFERENCES "USERS" ("ID") 
/

在 Hibernate 中映射用户表工作正常


<hibernate-mapping package="com.initech.domain">
    <class name="com.initech.User" table="USERS">

        <id name="id" column="ID" type="java.lang.Long">
            <meta attribute="use-in-tostring">true</meta>
            <generator class="sequence">
                <param name="sequence">SEQ_USERS_ID</param>
            </generator>
        </id>

        <property name="loginName" column="LOGINNAME" type="java.lang.String" not-null="true">
            <meta attribute="use-in-tostring">true</meta>
        </property>

    </class>
</hibernate-mapping>

但我在为 SpecialUsers 表创建映射时遇到了困难。我发现 Internet 中的所有示例(例如在 Hibernate 文档中)都没有这种类型的自引用。我尝试了这样的映射:


<hibernate-mapping package="com.initech.domain">
    <class name="com.initech.User" table="SPECIALUSERS">        

        <id name="id" column="USERID">
            <meta attribute="use-in-tostring">true</meta>
            <generator class="foreign">
                <param name="property">user</param>
            </generator>
        </id>

        <one-to-one name="user" class="User"/>

    </class>
</hibernate-mapping>

但得到了错误


Invocation of init method failed; nested exception is org.hibernate.DuplicateMappingException: 
Duplicate class/entity mapping com.initech.User 

我应该如何映射 SpecialUsers 表?我在应用程序级别需要的是包含在 SpecialUsers 表中的用户对象列表。

4

2 回答 2

2

我应该如何映射 SpecialUsers 表?

根据您的USERS和表的结构,每个子类层次结构SPECIALUSERS都有一个表,并且完全可以使用 Hibernate 映射这种层次结构

首先,确保在对象模型级别SpecialUser 继承User(这是继承关系,而不是自引用)。

public class SpecialUser extends User { 
}

然后,在的映射中声明一个<joined-subclass>元素:User

<hibernate-mapping package="com.initech.domain">
    <class name="com.initech.User" table="USERS">

        <id name="id" column="ID" type="java.lang.Long">
            <meta attribute="use-in-tostring">true</meta>
            <generator class="sequence">
                <param name="sequence">SEQ_USERS_ID</param>
            </generator>
        </id>

        <property name="loginName" column="LOGINNAME" type="java.lang.String" not-null="true">
            <meta attribute="use-in-tostring">true</meta>
        </property>

        <joined-subclass name="com.initech.SpecialUser" table="SPECIALUSERS">
            <key column="USERID"/>
        </joined-subclass>

    </class>
</hibernate-mapping>

我在应用程序级别需要的是包含在 SpecialUsers 表中的用户对象列表。

以下 HQL 查询将返回所有SpecialUserUser也是):

from SpecialUser

如果稍后您需要向SPECIALUSERS表中添加列,请将相应的属性添加到SpecialUser类中并将它们映射到<joined-subclass>元素内。有关详细信息,请参阅提供的链接(指向文档)。

于 2010-02-24T17:00:12.117 回答
1

如果您确实必须使用第二个表,则必须将其映射到一个新类。Hibernate 总是只能将一张表映射到一个类。

或者,在用户表中添加一列,上面写着“这个用户很特殊”。如果这不是一个选项,请创建一个连接两个表的视图,从而模拟此列。然后,您可以通过此列选择用户。

如果您采用两类方式,则必须加载特殊用户列表并在应用程序中进行映射。

[编辑] 也许你应该研究一下亲子关系。在您的情况下,用户是父母,其角色是孩子。因此,每个用户都有 0..n 个角色,这些角色映射在不同的表中。然后您可以使用此 HQL

from User u where :role in elements(u.roles)

查找具有特定角色的所有用户。但大多数时候,你会有一个特定的用户,只需要查询她是否有某个角色。

于 2010-02-24T15:23:41.713 回答