我有一个实体- 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
。
由于系统限制,我无法将这两个对象放在一个表中。(即使创建额外的字段也是个坏主意)。
我可以不进行子类化吗?使用Programmaticalyhibernate配置?
前言:
即使是在SO上,这也是一个普遍问到的问题,而且答案也与之相关Subclass
或实际上是SuperClass
接近的
映射示例:
<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 ]
赛后:
关于第一个问题的一个答案实际上是链接到这篇文章,有不同的方法:
您对对象的第一个实例说再见,将数据克隆到新实例,然后使用其他名称将其保留。
这样,就不会违反Hibernate逻辑和每个人的内容:两个表上的数据相同,不使用任何子类。
嗯,这种方法的实现,代码或可信度是这样的,我也没有对其进行测试。
另一种情况:
在这篇文章中,有另一个人试图用更简单的方法挑战超类方法,但是同样,最可靠的答案指出,不可能 采取 另一种方法,官方的非XML方法是所说的子类方法。
Hibernate为每个实体创建一个表,因此当我调用时,我的数据总是保存到这个表中。 现在,我需要另一个表来存储相同类型的数据,并且我只需要将我的实体保存到该表中。 数据结构(类似于以下内容): 由于系统的限制,我不能将这两个对象放在一个表中。(即使创建额外字段也是坏主意)。 我可以在不进行子类化的情况下这样做吗?使用programmaticaly hibernate配置?
问题内容: 我有一个实体- 。由描述。 Hibernate为每个实体创建一个表,因此当我调用时,我的数据总是保存到该表中。 现在,我需要另一个表来存储相同类型的数据,并且只需要将我的实体保存到该表中。 数据结构 (类似这样): 使用此方法 : 和结果,我应该在和 中。 由于系统限制,我无法将这两个对象放在一个表中。(即使创建额外的字段也是个坏主意)。 我可以不进行子类化吗?使用Programmat
AnsprechPartner Lieferant ansprechpartner.java lieferant.java 在我的AnsprechPartner.java中,我是这样做的: 在我的Lieferanten.java中,我是这样做的:
首先,我已经阅读了Hibernate——一个包含多个实体的表?。 然而,我希望将两个实体映射到同一个表,但我希望它们都是实体,我可以从中选择。我的意思是: 一个表:人(id、姓名、出生日期、城市、街道、邮政编码)。 两个实体:人(id、name、dateOfBirth)、地址(id、城市、街道、邮政编码)。 实体之间是1:1的关系,但数据库中仍然是1个表。 如果我在上面的链接中使用建议的解决方案(
我在实体类中设置一些hibernate注释时遇到问题。 我的问题是:我如何告诉Hibernate,它应该在一个表中存储地址、名称和客户信息。此表应包含以下列:ID、给定、姓氏、街道、门牌号、邮政编码、城市、电话、评论。目前,Hibernate在mysql数据库中为每个实体生成一个表。因此,有必要在每个实体类(客户、名称、地址)中定义@Id。但我想用一个@Id为客户保留一张表中的所有信息。 我怎样才
我有以下实体,它是应用程序中每个其他实体的基础实体: 我的目标是有两个表——图像和文件,以便这两个表共享给所有扩展BaseEntity的实体。我确实意识到,为此,所有扩展BaseEntity的实体都应该有一个共享id序列。 然后我有两个实体,它们是BaseEntity的子类型: 现在,当我设置时,hibernate为我生成以下表: 但是,我想要四张桌子: 我真的很感激任何帮助, 谢啦