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")
由于系统的限制,我不能将这两个对象放在一个表中。(即使创建额外字段也是坏主意)。
我可以在不进行子类化的情况下这样做吗?使用programmaticaly hibernate配置?
前言:
即使在SO上,这也是一个被广泛提出的问题,而且答案也广泛地与子类
或实际上的超类
方法相关(例如[1])
实际答案:
映射示例:
<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)
您告别对象的第一个实例,将数据克隆到新的实例中,并使用不同的名称保存该实例。因此,没有违反Hibernate逻辑和everybody内容:两个表中有相同的数据,并且没有使用子类。
嗯,这种方法的实现、代码或可信度都是如此,我也没有测试过它。
另一个案例:
[1]如何使用Hibernate/JPA注释将一个类映射到不同的表
[2]映射两个相同的表(相同的架构...)到Hibernate中的同一实体
[3]如何将2个相同的表(相同的属性)映射到1个实体
问题内容: 我有一个实体- 。由描述。 Hibernate为每个实体创建一个表,因此当我调用时,我的数据总是保存到该表中。 现在,我需要另一个表来存储相同类型的数据,并且只需要将我的实体保存到该表中。 数据结构 (类似这样): 使用这个 : 和结果,我应该在和 中。 由于系统限制,我无法将这两个对象放在一个表中。(即使创建额外的字段也是个坏主意)。 我可以不进行子类化吗?使用Programmati
问题内容: 我有一个实体- 。由描述。 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为我生成以下表: 但是,我想要四张桌子: 我真的很感激任何帮助, 谢啦