我有一个实体-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")
因此,我应该在user1
中使用users_1_table
,在user2
中使用users_2_table
。
由于系统限制,我无法将这两个对象放在一个表中。 (即使创建额外的字段也不是一个好主意)。
我可以不进行子类化吗?使用Programmaticaly休眠配置?
前言:
甚至在SO上,这也是一个普遍问的问题,而且答案也与Subclass
或实际上是SuperClass
方法(例如[1])有关]]
实际答案:
在这些帖子[2],[3]上,他们建议使用带有EntityName
参数的xml映射。
因此,使用xml进行映射,您不需要supeclass,只需将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)
帖子2和3用作此摘要的基础。官方消息[4]
赛后:
关于第一个问题的一个答案,实际上是链接到此帖子[5],有不同的方法:
您对对象的第一个实例说再见,将数据克隆到新的实例,并使用其他名称将其保留。这样,就不会违反Hibernate逻辑和每个人的内容:两个表上的数据相同,不使用任何子类。
嗯,这种方法的实现,代码或可信度是如此,所以我也没有对其进行测试。
另一种情况:
在这篇文章[6]中,有人试图用更简单的方法来挑战超类方法,但是同样,最可靠的答案指出,不可能以另一种方式解决问题,官方非XML方法是所说的子类方法。
来源
[1] How to map one class to different tables using hibernate/jpa annotations
[2] Map Two Identical tables ( same schema...) to same entity in Hibernate
[3] How to map 2 identical tables (same properties) to 1 entity
[4] http://docs.jboss.org/hibernate/core/3.2/reference/en/html/mapping.html#mapping-entityname
[5] Hibernate 4: One class mapping Two tables - How to persist one object on both tables?
[6] Hibernate Annotation for Entity existing in more than 1 catalog
还可以使用默认实体和替代实体:
您可以使用配置来完成:
尽管我从未使用过,但是在休眠状态下有一个辅助表的概念。 @SecondaryTables是休眠中的注释,实体可以通过该注释映射多个表以获取数据。正在获取数据的实体应具有@SecondaryTables批注。它根据主键和外键以及唯一约束来关联辅助表。
我知道这个问题是很久以前问过的。但我想提出一种替代方法,而不使用任何休眠方式。对于那些不想使用xml配置的人。