1、Session单表的CRUD操作

1、增加或者修改,使用同一个方法,或者下面的两个也行:

感觉多此一举。。。

2、删除方法,硬删除:

3、获取方法提供了两种,Get & Load

get方法

load方法

2、Get 和 Load 的区别?

使用get方法获取,如果查询的数据不存在则直接返回Null,即空指针。

如果使用Load方法获取,查询的数据不存在,则抛出异常。

3、JavaBean在Hibernate的Session中的持久化生命周期

一、瞬时状态

ORM对象和数据库不存在关联,且对象在数据库中没有关联记录,该对象的状态为瞬时状态。对象会被GC回收

二、持久状态

Bean与Session关联,被Session管理的情况下,该对象状态为持久状态。

也就是通过上述的Get,Load方法得到对象。调用save方法存入的对象也会被Session关联,变为持久状态

三、游离状态

脱离Session管理的bean对象,该对象状态即为游离状态

4、DirtyCheck 脏检查?

对象的属性发生变化的,称为脏对象,脏检查也就是对前面描述的对象进行检查

如果发现了脏变化,对象的属性发生改变,Session也要对应的将改变更新到数据库中,保证数据一致

5、FlushCache 缓存刷新

触发脏检查的方式就是刷新缓存,Session刷新的方式有两种,在commit提交的时候触发,二是手动调用flush方法触发

6、更新方法API详细

虽然说save也可以用来作更新操作,因为有OID就行,但是Hibernate还是提供了对应的更新方法

update 将游离状态的对象恢复持久状态,同时进行数据库更新操作,如果OID不存在则抛出异常

saveOrUpdate 包含save和update方法,参数是游离状态的对象就调用update执行

merge 将参数的游离状态对象复制属性到一个拥有相同OID的持久状态对象,通过对持久状态对象的脏检查进行更新操作,并返回

7、唯一结果 UniqueResult方法

查询返回的多个记录可以被List集合或者Iterator迭代器对象封装

二者皆可以被遍历处理,但是只有一个结果的情况,可以不需要集合对象处理,直接调用这个就行了

要注意的是,如果返回的结果不唯一,则Hibernate会抛出异常:NonUniqueResultException

8、分页与投影查询

一些分页需要的数据,使用Hibernate获取代码片段:

@Test
public void hibernatePaging() { Session session = HibernateUtil.getSession(); final String HQL_STATEMENT = "FROM xx.xx.xxx.DomainClass"; final Integer pageIndex = 10;
final Integer pageSize = 20; Query<Object> totalCountQuery = session.createQuery(HQL_STATEMENT, Object.class);
long count = totalCountQuery.stream().count();
Integer totalPage = new Long((count % pageSize == 0) ? (count / pageSize) : (count /pageSize + 1)).intValue(); Query<Object> pageListQuery = session.createQuery(HQL_STATEMENT, Object.class); pageListQuery.setFirstResult( (pageIndex - 1) * pageSize );
pageListQuery.setMaxResults( pageSize ); List<Object> objectList = pageListQuery.list();
}

一般来说封装的分页对象:

package cn.zeal4j.model;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import java.util.List; /**
* @author Administrator
* @file IntelliJ IDEA Hibernate-Tutorial
* @create 2020 09 26 19:10
*/
@Data
@AllArgsConstructor
@NoArgsConstructor
public class PageModel<Entity> {
private Integer pageIndex;
private Integer pageSize;
private Long totalCount;
private Integer totalPage;
private List<Entity> pageList; public void setTotalPage(Long totalCount) {
totalPage = new Long((totalCount % pageSize == 0) ?
(totalCount / pageSize) : (totalCount /pageSize + 1)).intValue();
}
}

使用分页模型处理:

只是写了一个大概的蓝图,实际操作再看吧

@Test
public void hibernatePaging2() {
// 参数
int index = 2;
int size = 20;
// 复杂一些还需要查询条件也封装进去才行,这里就不设置了
final String HQL_STATEMENT = "FROM xx.xx.xxx.DomainClass"; Session session = HibernateUtil.getSession(); Query<Object> query = session.createQuery(HQL_STATEMENT, Object.class); long count = query.stream().count(); PageModel<Object> pageModel = new PageModel<>(); pageModel.setPageIndex(index); pageModel.setPageSize(size); pageModel.setTotalCount(count); pageModel.setTotalPage(count); query.setFirstResult( (pageModel.getPageIndex() - 1) * pageModel.getPageSize() );
query.setMaxResults( pageModel.getPageSize() ); List<Object> objectList = query.list(); pageModel.setPageList(objectList); // 业务就可以返回这个包装的分页模型对象了
// return pageModel;
}

9、投影查询

数据的展示并不需要全部获取,只是部分的属性,或者使用表达式、函数、等获取结果

可以使用投影函数。有三种情景适用:

1、每条结果仅包含一个字段列,查询的结果泛型可以直接返回那个字段的类型

2、或者多个字段列,查询的结果泛型可以直接返回Object数组

3、结果通过构造器封装成对象,查询的结果就是映射的实体类对象

发现构造器查询是这样的。。。眼睛已经瞎掉了。。。

【Hibernate】Re01.5 API的更多相关文章

  1. 【Hibernate】Hibernate的多表查询

    在<[Hibernate]Hibernate的聚类查询.分组查询.排序与时间之差>(点击打开链接)一文中已经讲述过怎样利用HQL语句代替SQL语句.进行聚类查询.分组查询.排序与时间之差的 ...

  2. 【hibernate】映射继承关系

    [hibernate]映射继承关系 转载:https://www.cnblogs.com/yangchongxing/p/10405151.html ========================= ...

  3. 【hibernate】自定义转换器

    [hibernate]自定义转换器 转载:https://www.cnblogs.com/yangchongxing/p/10398255.html 1.转换基本属性 package cn.ycx.s ...

  4. 【hibernate】存储图片

    [hibernate]存储图片 转载: package cn.ycx.study.hibernate.entity; import javax.persistence.Entity; import j ...

  5. 【hibernate】映射可嵌入式组件

    [hibernate]映射可嵌入式组件 转载:https://www.cnblogs.com/yangchongxing/p/10376452.html 可嵌入 Address 类,没有对应的数据表 ...

  6. 【hibernate】应用程序级别的视图

    [hibernate]应用程序级别的视图 转载:https://www.cnblogs.com/yangchongxing/p/10361281.html 在没有数据库修改权限时,像创建视图可以使用 ...

  7. 【hibernate】重写物理表名和列明

    [hibernate]重写物理表名和列明 转载:https://www.cnblogs.com/yangchongxing/p/10357123.html 假设你的数据库命名有这样的需求,表都以 yc ...

  8. 【hibernate】常用注解

    [hibernate]常用注解 转载:https://www.cnblogs.com/yangchongxing/p/10357118.html 目录 ======================== ...

  9. 【译】Android NDK API 规范

    [译]Android NDK API 规范 译者按: 修改R代码遇到Lint tool的报错,搜到了这篇文档,aosp仓库地址:Android NDK API Guidelines. 975a589 ...

  10. 【算法】实现字典API:有序数组和无序链表

    参考资料 <算法(java)>                           — — Robert Sedgewick, Kevin Wayne <数据结构>       ...

随机推荐

  1. ABC317题解报告

    我直接从第三题开始讲了. T3 把数组 \(A\) 从大到小排序. 然后从前往后把前 \(q\) 个数加起来,然后判断这 \(q\) 个数的和与 \(d\) 的大小关系,如果大了就变成 \(d\). ...

  2. Vector | Graph:蚂蚁首个开源Graph RAG框架设计解读

    检索增强生成(RAG:Retrieval Augmented Generation)技术旨在把信息检索与大模型结合,以缓解大模型推理"幻觉"的问题.近来关于RAG的研究如火如荼,支 ...

  3. 【已结束】阿珏Blog三周年特别纪念活动

    Tips:当你看到这个提示的时候,说明当前的文章是由原emlog博客系统搬迁至此的,文章发布时间已过于久远,编排和内容不一定完整,还请谅解` [已结束]阿珏Blog三周年特别纪念活动 日期:2019- ...

  4. 记一次 .NET某机械臂上位系统 卡死分析

    一:背景 1. 讲故事 前些天有位朋友找到我,说他们的程序会偶发性的卡死一段时间,然后又好了,让我帮忙看下怎么回事?窗体类的程序解决起来相对来说比较简单,让朋友用procdump自动抓一个卡死时的du ...

  5. Postman 的 Basic Auth 如何通过 Feign 实现

    Postman 的 Basic Auth: 分析 根据以上图片分析: Postman 的 Authorization 实际为: header 中添加 Authorization: ******* ** ...

  6. 苹果应用商店上传应用卡在了“Authenticating with the iTunes Store”

    在终端中依次运行下面代码 cd ~ mv .itmstransporter/ .old_itmstransporter/ "/Applications/Xcode.app/Contents/ ...

  7. 认真学习css3-2-css的选择器

    关于有哪些选择器,具体可以查看w3school. 本文写了一个考卷的例子,带有部分js,jquery.不会针对每个选择器做示例,只练习了一些常用的,有意思的. 先看html/js代码: <!DO ...

  8. Kubernetes容器生命周期 —— 钩子函数详解(postStart、preStop)

    1.概述 容器生命周期钩子(Container Lifecycle Hooks)监听容器生命周期的特定事件,并在事件发生时执行已注册的回调函数. 钩子函数能够感知自身生命周期中的事件,并在相应的时刻到 ...

  9. 详解Web应用安全系列(9)点击劫持

    点击劫持(Clickjacking)漏洞,也被称为界面伪装攻击(UI Redress Attack)或UI覆盖攻击,是一种利用视觉欺骗手段进行的网络攻击方式.这种攻击方式通过技术手段欺骗用户点击他们本 ...

  10. Solo 开发者周刊 (第3期):如何打造令人惊艳的AI体验

    这里会整合 Solo 社区每周推广内容.产品模块或活动投稿,每周五发布.在这期周刊中,我们将深入探讨开源软件产品的开发旅程,分享来自一线独立开发者的经验和见解.本杂志开源,欢迎投稿. 好文推荐 Plu ...