hibernate two tables per one entity

我有一个实体- 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)

以上是 hibernate two tables per one entity 的全部内容, 来源链接: utcz.com/qa/411660.html

回到顶部