如何解决在JPA或Hibernate中,“持久类”和“实体”有什么区别?
第一件事:
- 我知道this这个问题,在较高的抽象水平上,我也要问同样的问题;但是,我发现它(及其答案)缺乏,因此,我想在这里详细说明这个主题;
- 我想请对JPA和Hibernate中的正式定义有深入了解的任何人来帮助我弄清这一点。
免责声明:我不是在寻找有关实体是什么以及如何使用它的基本解释。我已经使用Hibernate / JPA相当一段时间了。
我的问题更多地是关于形式定义,以便阐明 Entity 和持久类之间的形式语义(定义)的区别。 ,以使人与人之间的区别以及如何定义变得十分清晰。
最初,我希望可以在JSR 338: JPA Specification 2.2和Hibernate 5.0.0 Reference Documentation中找到答案,但由于感到有些困惑,在这种情况下,两个文档都缺乏,我感到非常困惑,这些概念/定义有很大的重叠空间,并引起一些猜测。
让我们从JSR 338开始:JPA 2.2规范:
由于某些原因(对我来说很奇怪),在整个说明书中,找不到关键词短语“ Persistent Object”和“ Persistent Class”,分别只有一次和两次:
- 持久性对象-在Javadoc注释中找到,什么也没说(第221页)
- 持久类-再次在xsd文档中找到,没有多说(页面:378,529)
而且,不幸的是,在本规范中仅此而已。
实体类的定义如下:
实体是轻量级的持久域对象。主要的编程工件是实体类。实体类可以使用辅助类 用作帮助程序类或用于表示实体状态的
再次,我发现正式的规范文档非常缺乏,但是至少,这表明它是一个持久域对象。
在同一文档中, Entity 也被定义为一个类(2.1 Entity Class,第23页)。
尽管这看起来似乎并不重要,但将其定义为持久对象还是 Class 还是很令人困惑。
基于此规范文档的结论:
- 持久类/对象完全没有在JPA 2.2规范中定义;
- 实体定义为持久对象,和(!),作为类,这实际上是我不清楚;
根据我的概念理解,持久对象听起来很像一个对象,可以持久 if(!)对应地映射;因此,如果 Persistent Class -作为 Class ,则其实例可以持久化(即,可以通过遵循POJO概念将其存储到数据库层中),如果类被相应地映射。即 Persistent Class 是一个持久化 able 类,如果它具有其对应的映射定义(使用.hbm.xml或JPA注释)。
Hibernate 5参考文档
另一方面,休眠defines 持久类,它的操作如下:
持久类是应用程序中实现业务问题实体的类(例如,电子商务应用程序中的客户和订单)。这里的“持久”一词表示这些类能够持久化,而不是处于持久状态。
我得到了正确的答案,即 Persistent Classes实现了实体的意思是,我的理解是正确的,而 Persistent Class 只是一个Java类,它实现了 Entity 模型(无映射),并与它的映射(.hbm.xml或JPA)一起成为 Entity ? 持久类+映射定义=实体是正确的吗?
我还将在此处插入Java Persistence with Hibernate,Second Edition书中的一些摘录:
您编写了一个持久类及其带有注释的映射。 -(摘要2.4);
的种类,将持久性类与其映射区分开来,并且再次支持这种观点,即持久性类及其映射是不同的概念,从逻辑上讲,仅持久性类并不是实体。
持久性类不知道并且不依赖于持久性机制。 -(第3.2章);
明确指出,持久性类不了解持久性机制。
例如,您可以在持久性上下文之外重用持久性类,例如在单元测试或表示层中。您可以使用常规Java new运算符在任何运行时环境中创建实例,从而保留可测试性和可重用性。 -(第3.2章)。
也支持持久性类不一定是映射实体的想法。
我的结论:
(基于我的初步理解,《 Hibernate参考文档》和《 Java Persistence with Hibernate,第二版》一书对此表示支持。)>
持久类是Java类,(如果需要!)将符合JPA规范(据此,它们必须是POJO,并且可以映射),但不是实体(如果未映射),它们可以在JPA外部环境中使用,以像在普通Java对象上一样对其进行操作,甚至可以在表示层上进行显示。
最后:
如您所见,我的问题有点是不同资源的混合,显示出我明显的困惑,因为我无法清楚地定义正式,即所谓的科学采用 >这两个概念的定义。
我们可以清楚地定义什么是持久性类,什么是实体以及什么是语义和限定性在JPA和Hibernate方面它们之间的区别/重叠?
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。