当前位置: 首页 > 知识库问答 >
问题:

每个实体Hibernate两个表

孙明德
2023-03-14

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配置?

共有1个答案

宋宏儒
2023-03-14

前言:

即使在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为我生成以下表: 但是,我想要四张桌子: 我真的很感激任何帮助, 谢啦