在JPA或Hibernate中,“持久类”和“实体”有什么区别?

如何解决在JPA或Hibernate中,“持久类”和“实体”有什么区别?

第一件事:

  1. 我知道this这个问题,在较高的抽象水平上,我也要问同样的问题;但是,我发现它(及其答案)缺乏,因此,我想在这里详细说明这个主题;
  2. 我想请对JPA和Hibernate中的正式定义有深入了解的任何人来帮助我弄清这一点。

免责声明:我不是在寻找有关实体是什么以及如何使用它的基本解释。我已经使用Hibernate / JPA相当一段时间了。

我的问题更多地是关于形式定义,以便阐明 Entity 持久类之间的形式语义(定义)的区别。 ,以使人与人之间的区别以及如何定义变得十分清晰。

最初,我希望可以在JSR 338: JPA Specification 2.2Hibernate 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 还是很令人困惑。

基于此规范文档的结论:

  1. 持久类/对象完全没有在JPA 2.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 举报,一经查实,本站将立刻删除。

相关推荐


使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams['font.sans-serif'] = ['SimHei'] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -> systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping("/hires") public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate<String
使用vite构建项目报错 C:\Users\ychen\work>npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-
参考1 参考2 解决方案 # 点击安装源 协议选择 http:// 路径填写 mirrors.aliyun.com/centos/8.3.2011/BaseOS/x86_64/os URL类型 软件库URL 其他路径 # 版本 7 mirrors.aliyun.com/centos/7/os/x86
报错1 [root@slave1 data_mocker]# kafka-console-consumer.sh --bootstrap-server slave1:9092 --topic topic_db [2023-12-19 18:31:12,770] WARN [Consumer clie
错误1 # 重写数据 hive (edu)> insert overwrite table dwd_trade_cart_add_inc > select data.id, > data.user_id, > data.course_id, > date_format(
错误1 hive (edu)> insert into huanhuan values(1,'haoge'); Query ID = root_20240110071417_fe1517ad-3607-41f4-bdcf-d00b98ac443e Total jobs = 1
报错1:执行到如下就不执行了,没有显示Successfully registered new MBean. [root@slave1 bin]# /usr/local/software/flume-1.9.0/bin/flume-ng agent -n a1 -c /usr/local/softwa
虚拟及没有启动任何服务器查看jps会显示jps,如果没有显示任何东西 [root@slave2 ~]# jps 9647 Jps 解决方案 # 进入/tmp查看 [root@slave1 dfs]# cd /tmp [root@slave1 tmp]# ll 总用量 48 drwxr-xr-x. 2
报错1 hive> show databases; OK Failed with exception java.io.IOException:java.lang.RuntimeException: Error in configuring object Time taken: 0.474 se
报错1 [root@localhost ~]# vim -bash: vim: 未找到命令 安装vim yum -y install vim* # 查看是否安装成功 [root@hadoop01 hadoop]# rpm -qa |grep vim vim-X11-7.4.629-8.el7_9.x
修改hadoop配置 vi /usr/local/software/hadoop-2.9.2/etc/hadoop/yarn-site.xml # 添加如下 <configuration> <property> <name>yarn.nodemanager.res