1. 实体域对象:通常实体域对象与数据库表中的记录对应,可以为每个实体域对象分配唯一的一个OID(Object Identifier 对象标帜符),OID是关系数据库的主键,通常是代理主键在实体域对象中的等价物。
2. 过程域对象:
3. 事件域对象:由系统中其他功能所出发的异常、警告或超时等信息。
4. 关联(Association):关联指的是类之间的引用关系,是实体域对象之间最普遍的一种关系,关联可以分为一对一、一对多和多对多。
5. 依赖(Dependency):指的是类之间的访问关系,如果A类访问B类的属性和方法,或者A类负责实例化B类,可以说A类依赖B类,和关联关系不同,无需把B类定义为A类的属性。依赖在实体域对象之间是不常见的,但是过程域对象往往依赖实体域对象,因为过程域对象会创建实体域对象。或者会访问实体域对象的方法和属性。
6. 聚集(Aggregation):聚集关系与关联关系在类的定义上有相同的形式,不过两者有不同的语义,对于聚集关系,部分类的对象不能够单独存在,他的生命周期依赖于整体类对象的生命周期,当整体消失时,部分也随之消失,而对于存在关联关系的两个类却允许各自的对象单独存在。聚集关系与关联关系的语义区别是通过业务逻辑来保证的。通常由过程域对象来实现。在ORM中间件的四层应用中,可以在对象-关系映射文件中采用不同的映射元数据来区分两种关系。
7. 一般化(Generalization):通常指的是类之间的继承关系。
8. 持久化过程:
增加:把域对象永久保存到数据库
删除:从数据库中删除一个域对象
修改:更新数据库中域对象的状态
查询:把符合条件的一个或多个对象从数据库加载到内存中
加载:根据特定的OID,把一个域对象从数据库加载到内存中
9. ORM模式(Object-Relation Mapping):指的是在单个组件中负责所有实体域对象的持久化,封装数据访问细节。
ORM持久化方法:
1) 为每一种可能的数据库访问操作提供单独的方法。
缺点:
² 持久化层产生大量冗余代码
² 持久化层缺乏弹性
² 持久化层同时与域模型和关系数据模型绑定
2) 采用映射元数据来描述对象-关系的映射细节,使得ORM可以在业务逻辑层和数据库层之间承担桥梁的作用。
10. 对象的删除操作:
1)运用反射机制或得对象的类型
2)参考对象-关系映射元数据,获取对象关联信息
3)自动生成DML语句
4)调用JDBC API执行以上SQL
说明:事实上,Hibernate在初始化阶段就会根据映射信息预定义一些增删改查的SQL语句,这些语句存放在SessionFactory的缓存中,当执行删除操作时直接进行调用就可以了。
11. 其他持久化模式:主动域对象模式、JDO模式、CMP模式
主动域对象模式:
优点:
² 实体域负责数据访问细节把业务访问细节交给过程域完成
² 当关系模型发生改变时,只需修改主动域对象的代码不需修改过程域对象的业务方法
缺点:
² 实体域对象的实现中仍然包含SQL语句
² 每个实体域对象都负责自身的数据访问实现,将这一职责分散到多个对象中,这会导致实体域对象重复实现一些共同的数据访问操作从而造成重复编码。
JDO模式:支持把对象持久化到任意一种存储系统中:关系数据库、面向对象的数据库、基于XML的数据库和其他专有存储系统。
CMP模式:
缺点:
² 必须遵循J2EE规范
² 只能运行在EJB容器中
² 对于复杂的与模型,EJB提供的对象-关系映射能力很有限。
² 由于不同厂商生产的CMP引擎差异很大,对象-关系映射元数据也各不相同导致可移植性很差
12. Hibernate API说明:
提供操作数据库的接口,包括:Session、Transaction和Query
用于配置Hibernate的接口:Configuration
回调接口,是程序接受Hibernate内部发生事件,并做出相关回应,接口包括:Interceptor、Lifecycle和Validatable
用于扩展Hibernate的功能接口,UserType、CompositeUserType和IdentifierGenerator,如果需要的话应用程序可以扩展这些接口。
13. Hibernate的5个核心接口:
² Configuration接口:配置和启动Hibernate,创建SessionFactory对象
java 代码
- private static final SessionFactory sessionFactory;
- static {
- try {
-
- sessionFactory = new Configuration().configure().buildSessionFactory();
- } catch (Throwable ex) {
- System.err.println("Initial SessionFactory creation failed." + ex);
- throw new ExceptionInInitializerError(ex);
- }
- }
-
- public static SessionFactory getSessionFactory() {
- return sessionFactory;
- }
² SessionFactory接口:初始化Hibernate,充当数据存储源的代理,创建Session对象
java 代码
- Session session=HibernateUtil.getSessionFactory().getCurrentSession();
java 代码
- session.beginTransaction();
- session.delete(persistentInstance);
² Transaction接口:管理事务
java 代码
- session.getTransaction().commit();
java 代码
- String strSQL="select p from Person p left join fetch p.events where p.id = :pid";
-
- Person aPerson=(Person)session.createQuery(strSQL).setParameter("pid",personId).uniqueResult();
² Query和Criteria接口:执行数据库查询² Session接口:负责对象的增删改查和加载操作
分享到:
相关推荐
串流分屏 - 两台笔记本电脑屏幕共享
tornado-6.3.2-cp38-abi3-musllinux_1_1_x86_64.whl
基于java的银行业务管理系统答辩PPT.pptx
TA_lib库(whl轮子),直接pip install安装即可,下载即用,非常方便,各个python版本对应的都有。 使用方法: 1、下载下来解压; 2、确保有python环境,命令行进入终端,cd到whl存放的目录,直接输入pip install TA_lib-xxxx.whl就可以安装,等待安装成功,即可使用! 优点:无需C++环境编译,下载即用,方便
"Turkish Law Dataset for LLM Finetuning" 是一个专为法律领域预训练的大型语言模型(LLM)微调而设计的数据集。这个数据集包含了大量的土耳其法律文本,旨在帮助语言模型更好地理解和处理土耳其法律相关的查询和文档。 该数据集的特点包括: 专业领域:专注于土耳其法律领域,提供了大量的法律文本和案例,使模型能够深入学习法律语言和术语。 大规模:数据集规模庞大,包含了超过1000万页的法律文档,总计约135.7GB的数据,这为模型提供了丰富的学习材料。 高质量:数据经过清洗和处理,去除了噪声和非句子文本,提高了数据质量,使得模型训练更加高效。 预训练与微调:数据集支持预训练和微调两个阶段,预训练阶段使用了大量的土耳其语网页数据,微调阶段则专注于法律领域,以提高模型在特定任务上的表现。 多任务应用:微调后的模型可以应用于多种法律相关的NLP任务,如法律文本摘要、标题生成、文本释义、问题回答和问题生成等。 总的来说,这个数据集为土耳其法律领域的自然语言处理研究提供了宝贵的资源,有助于推动土耳其语法律技术的发展,并为法律专业人士提供更精准的技术支持。通过微调,
农业信息化服务平台 SSM毕业设计 附带论文 启动教程:https://www.bilibili.com/video/BV1GK1iYyE2B
tornado-6.1b2-cp36-cp36m-manylinux2010_i686.whl
计算机NLP_预训练模型文件
随心淘网管理系统 SSM毕业设计 附带论文 启动教程:https://www.bilibili.com/video/BV1GK1iYyE2B
计算机汇编杂谈-理解其中的原理
基于java的藏区特产销售平台答辩PPT.pptx
本压缩包资源说明,你现在往下拉可以看到压缩包内容目录 我是批量上传的基于SpringBoot+Vue的项目,所以描述都一样;有源码有数据库脚本,系统都是测试过可运行的,看文件名即可区分项目~ |Java|SpringBoot|Vue|前后端分离| 开发语言:Java 框架:SpringBoot,Vue JDK版本:JDK1.8 数据库:MySQL 5.7+(推荐5.7,8.0也可以) 数据库工具:Navicat 开发软件: idea/eclipse(推荐idea) Maven包:Maven3.3.9+ 系统环境:Windows/Mac
安装包
项目经过测试均可完美运行! 环境说明: 开发语言:java jdk:jdk1.8 数据库:mysql 5.7+ 数据库工具:Navicat11+ 管理工具:maven 开发工具:idea/eclipse
项目经过测试均可完美运行! 环境说明: 开发语言:java jdk:jdk1.8 数据库:mysql 5.7+ 数据库工具:Navicat11+ 管理工具:maven 开发工具:idea/eclipse
Windows x64 操作系统上安装 Python 3.11 版本对应的dlib库,操作简单,无需pip在下载,再也不怕网络超时等其他不确定错误 使用方法: 1、确保windows x64系统上安装了python,可以用anaconda自带的python 2、确认python版本为3.11版本 3、下载资源解压为dlib-19.24.1-cp311-cp311-win_amd64.whl到本地,cd到对应目录,终端直接输入命令pip install dlib-19.24.1-cp311-cp311-win_amd64.whl 等待安装成功提示就可以用了,非常方便,有使用问题欢迎私信哟!
Jira插件安装包
项目经过测试均可完美运行! 环境说明: 开发语言:java jdk:jdk1.8 数据库:mysql 5.7+ 数据库工具:Navicat11+ 管理工具:maven 开发工具:idea/eclipse
tornado-6.1b2.tar.gz