我有一个实体- Use
r。由描述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")
和结果,我应该user1
在users_1_table
和user2
中users_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)