当前位置: 首页 > 面试题库 >

hibernate two tables per one entity

华景同
2023-03-14
问题内容

我有一个实体- User。由描述User.class

Hibernate为每个实体创建一个表,因此当我调用时session.save(user),我的数据总是保存到该表中。

现在,我需要另一个表来存储相同User类型的数据,并且只需要将我的实体保存到该表中。

数据结构(类似这样):

table users_1_table{
  string id;
  string username;
}

table users_2_table{
  string id;
  string username;
}

使用这个:

session.save(user1,"users_1_table")
session.save(user2,"users_2_table")

和结果,我应该user1users_1_tableuser2users_2_table

由于系统限制,我无法将这两个对象放在一个表中。(即使创建额外的字段也是个坏主意)。

我可以不进行子类化吗?使用Programmaticalyhibernate配置?


问题答案:

使用xml映射不需要超类,只需将EntityName参数提供给两个相同的映射即可。

映射示例:

<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2">
   <class name="DomainModel.User, DomainModel"
     table="User1Object" entity-name="User1Object">  
         <id name="_id" access="field" column="id">
             <generator class="assigned"/>
         </id>
        <property name= ...>
 </class>
 <class name="DomainModel.User, DomainModel"
     table="User2Object" entity-name="User2Object">
         <id name="_id" access="field" column="id">
            <generator class="assigned"/>
         </id>
        <property name= ...>
</class>
</hibernate-mapping>

然后根据所需的实体类型,调用适当的会话方法,如下所示:

_session.Save("User1Object", user1)

要么

_session.Save("User2Object", user2)


 类似资料:

相关阅读

相关文章

相关问答