当前位置: 首页 > 面试题库 >

每个实体hibernate两个表

姬俊驰
2023-03-14
问题内容

我有一个实体- 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")

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