hibernate学习笔记04

本文介绍Hibernate框架下多种查询方式,包括对象导航查询、HQL查询、QBC查询等,并详细讲解了每种查询方式的具体用法及注意事项。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

hibernate知识点
1 hibernate的查询方式
2 对象导航查询
3 hql查询
(1)查询所有
(2)条件查询
(3)排序查询
(4)分页查询
(5)投影查询
(6)聚集函数使用
4 qbc查询
(1)查询所有
(2)条件查询
(3)排序查询
(4)分页查询
(5)统计查询
(6)离线查询
5 hql多表查询
(1)mysql多表查询回顾
(2)hql多表查询
- 内连接、迫切内连接、左外连接、迫切左外连接、右外连接
6 hibernate的检索策略
(1)概念
- hibernate分成 :立即和延迟查询
- 延迟查询分成:类级别和关联级别延迟
(2)具体操作

Hibernate查询方式
1 对象导航查询
(1)根据id查询某个客户,再查询这个客户里面所有的联系人

2 OID查询
(1)根据id查询某一条记录,返回对象

3 HQL查询
(1)Query对象,写hql语句实现查询

4 QBC查询
(1)Criteria对象

5 本地sql查询
(1)SQLQuery对象,使用普通sql实现查询

对象导航查询
1 查询某个客户里面所有联系人过程,使用对象导航实现

2 代码
//根据cid=1客户,再查询这个客户里面所有联系人
Customer customer = session.get(Customer.class, 1);
//再查询这个客户里面所有联系人
//直接得到客户里面联系人的set集合
Set linkman = customer.getLinkMans();
System.out.println(linkman.size());

OID查询
1 根据id查询记录
(1)调用session里面的get方法实现
Customer customer = session.get(Customer.class, 2);

HQL查询
1 hql:hibernate query language,hql语言和普通sql很相似,
区别:普通sql操作数据库表和字段,hql操作实体类和属性

2 常用的hql语句
(1)查询所有: from 实体类名称
(2)条件查询: from 实体类名称 where 属性名称=?
(3)排序查询: from 实体类名称 order by 实体类属性名称 asc/desc

3 使用hql查询操作时候,使用Query对象
(1)创建Query对象,写hql语句
(2)调用query对象里面的方法得到结果

查询所有
1 查询所有客户记录
(1)创建Query对象,写hql语句
(2)调用query对象里面的方法得到结果

2 查询所有: from 实体类名称
//1 创建query对象
Query query = session.createQuery(“from Customer”);
//2 调用方法得到结果
List list = query.list();

条件查询
1 hql条件查询语句写法:
(1) from 实体类名称 where 实体类属性名称=? and实体类属性名称=?
from 实体类名称 where 实体类属性名称 like ?

2 代码
//1 创建query对象
Query query = session.createQuery(“from Customer c where c.cid=? and c.custName=?”);
//2 设置条件值
// 向?里面设置值 setParameter方法两个参数
// 第一个参数:int类型是?位置,?位置从0开始
// 第二个参数:具体参数值
query.setParameter(0, 1);
query.setParameter(1, “百度”);
List list = query.list();

模糊查询
//1 创建query对象
Query query = session.createQuery(“from Customer c where c.custName like ?”);
//2 设置?的值
query.setParameter(0, “%浪%”);
//3 调用方法得到结果
List list = query.list();

排序查询
1 hql排序语句写法
(1)from 实体类名称 order by 实体类属性名称 asc升(默认)/desc降
//1 创建query对象
Query query = session.createQuery(“from Customer order by cid desc”);
//2 调用方法得到结果
List list = query.list();

分页查询
1 mysql实现分页
(1)使用关键字 limit实现
select * from t_customer limit 0,3;
2 在hql中实现分页
(1)在hql操作中,在语句里面不能写limit,hibernate的Query对象封装两个方法实现分页操作
Query query = session.createQuery(“from Customer”);
// 设置分页数据
//1 设置开始位置
query.setFirstResult(0);
/.2 设置每页记录数
query.setMaxResults(3);
List list = query.list();

投影查询
1 投影查询:查询不是所有字段值,而是部分字段的值

2 投影查询hql语句写法:
(1)select 实体类属性名称1, 实体类属性名称2 from 实体类名称
(2)select 后面不能写 * ,不支持的

3 具体实现
//1 创建query对象
Query query = session.createQuery(“select custName from Customer”);
//2 调用方法得到结果
List list = query.list();

聚集函数使用
1 常用的聚集函数
(1)count、sum、avg、max、min

2 hql聚集函数语句写法
(1)查询表记录数
- select count(*) from 实体类名称

Query query = session.createQuery(“select count(*) from Customer”);
//2 调用方法得到结果
//query对象里面有方法,直接返回对象形式
Object obj = query.uniqueResult();
//返回int类型
//首先把object变成long类型,再变成int类型
Long lobj = (Long) obj;
int count = lobj.intValue();
System.out.println(count);
注:若直接把object对象转为int对象,会产生ClassCastException类型转换异常

QBC查询
1 使用hql查询需要写hql语句实现,但是使用qbc时候,不需要写语句了,使用方法实现

2 使用qbc时候,操作实体类和属性

3 使用qbc,使用Criteria对象实现

查询所有
1 创建Criteria对象
2 调用方法得到结果
//1 创建对象
Criteria criteria = session.createCriteria(Customer.class);
//2 调用方法得到结果
List list = criteria.list();

条件查询
1 没有语句,使用封装的方法实现
//1 创建对象
Criteria criteria = session.createCriteria(Customer.class);
//2 使用Criteria对象里面的方法设置条件值
// 首先使用add方法,表示设置条件值
// 在add方法里面使用类的方法实现条件设置
//criteria.add(Restrictions.eq(“cid”, 1));
//criteria.add(Restrictions.eq(“custName”, “百度”));
criteria.add(Restrictions.like(“custName”, “%百%”));
List list = criteria.list()

排序查询
//1 创建对象
Criteria criteria = session.createCriteria(Customer.class);
//2 设置对哪个属性进行排序,设置排序规则
criteria.addOrder(Order.desc(“cid”));
//3 调用方法得到结果
List list = criteria.list();

分页查询
开始位置计算公式: (当前页-1)*每页记录数
//1 创建对象
Criteria criteria = session.createCriteria(Customer.class);
//2 设置分页数据
//2.1 设置开始位置
criteria.setFirstResult(0);
//2.2 每页显示记录数
criteria.setMaxResults(3);

统计查询
//1 创建对象
Criteria criteria = session.createCriteria(Customer.class);
//2 设置操作
criteria.setProjection(Projections.rowCount());
//3 调用方法得到结果
Object obj = criteria.uniqueResult();
Long lobj = (Long) obj;
int count = lobj.intValue();

离线查询
1 servlet调用service,service调用dao
(1)在dao里面对数据库crud操作
(2)在dao里面使用hibernate框架,使用hibernate框架时候,调用session里面的方法实现功能
//1 创建对象
//Criteria criteria = session.createCriteria(Customer.class);
DetachedCriteria detachedCriteria = DetachedCriteria.forClass(Customer.class);
//2 最终执行时候才需要到session
Criteria criteria = detachedCriteria.getExecutableCriteria(session);
List list = criteria.list();

HQL多表查询
Mysql里面多表查询
1 内连接(只有表有关联的数据才显示)

2 左外连接(左表所有数据右表关联数据)

3 右外连接(有表所有数据左表关联数据)

HQL实现多表查询
Hql多表查询
(1)内连接
(2)左外连接
(3)右外连接
(4)迫切内连接
(5)迫切左外连接
HQL内连接
1 内连接查询hql语句写法:以客户和联系人为例
(1)from Customer c inner join c.setLinkMan
返回list,list里面每部分是数组形式
//1 创建query对象
Query query = session.createQuery(“from Customer c inner join c.setLinkMan”);
List list = query.list();

2 演示迫切内连接
(1)迫切内连接和内连接底层实现一样的
(2)区别:使用内连接返回list中每部分是数组,迫切内连接返回list每部分是对象
(3)hql语句写法
from Customer c inner join fetch c.linkMans;

HQL左外连接
1 左外连接hql语句:
(1)from Customer c left outer join c.linkMans
(2)迫切左外连接from Customer c left outer join fetch c.linkMans

2 左外连接返回list中每部分是数组,迫切左外连接返回list每部分是对象

1 右外连接hql语句:
(1)from Customer c right outer join c.setLinkMan

Hibernate检索策略
检索策略的概念
1 hibernate检索策略分为两类:
(1)立即查询:根据id查询,调用get方法,一调用get方法马上发送语句查询数据库
//根据cid=1客户,再查询这个客户里面所有联系人
Customer customer = session.get(Customer.class, 1);
//再查询这个客户里面所有联系人
//直接得到客户里面联系人的set集合
//得到set集合,没有发送语句
Set linkman = customer.getLinkMans();
(2)延迟查询:根据id查询,还有load方法,调用load方法不会马上发送语句查询数据,只有得到对象里面的值时候才会发送语句查询数据库
//根据cid=1客户
/*
* 1 调用load方法之后,不会马上发送sql语句
* (1)返回对象里面只有 id值
* 2 得到对象里面不是id的其他值时候才会发送语句
* */
Customer customer = session.load(Customer.class, 2);
System.out.println(customer.getCid());
System.out.println(customer.getCustName());

2 延迟查询分成两类:
(1)类级别延迟:根据id查询返回实体类对象,调用load方法不会马上发送语句
(2)关联级别延迟:
- 查询某个客户,再查询这个客户的所有联系人,查询客户的所有联系人的过程是否需要延迟,这个过程称为关联级别延迟

关联级别延迟操作
1 在映射文件中进行配置实现
(1)根据客户得到所有的联系人,在客户映射文件中配置

2 在set标签上使用属性
(1)fetch:值select(默认)
(2)lazy:值
- true:延迟(默认)执行代码时发送语句

  • false: 没有延迟 调用get之后,发送两条sql语句

  • extra:极其延迟 极其懒惰,要什么值给什么值

批量抓取
1 查询所有的客户,返回list集合,遍历list集合,得到每个客户,得到每个客户的所有联系人
(1)batch-size值,值越大发送语句越少
//查询所有客户
Criteria criteria = session.createCriteria(Customer.class);
List list = criteria.list();
//得到每个客户里面所有的联系人
for (Customer customer : list) {
System.out.println(customer.getCid()+”::”+customer.getCustName());
//每个客户里面所有的联系人
Set setLinkMan = customer.getLinkMans();
for (LinkMan linkMan : setLinkMan) {
System.out.println(linkMan.getLkm_id()+”::”+linkMan.getLkm_name());
}
}
上面操作代码,发送多条sql语句

2 在客户的映射文件中,set标签配置

内容概要:本文详细介绍了扫描单分子定位显微镜(scanSMLM)技术及其在三维超分辨体积成像中的应用。scanSMLM通过电调透镜(ETL)实现快速轴向扫描,结合4f检测系统将不同焦平面的荧光信号聚焦到固定成像面,从而实现快速、大视场的三维超分辨成像。文章不仅涵盖了系统硬件的设计与实现,还提供了详细的软件代码实现,包括ETL控制、3D样本模拟、体积扫描、单分子定位、3D重建和分子聚类分析等功能。此外,文章还比较了循环扫描与常规扫描模式,展示了前者在光漂白效应上的优势,并通过荧光珠校准、肌动蛋白丝、线粒体网络和流感A病毒血凝素(HA)蛋白聚类的三维成像实验,验证了系统的性能和应用潜力。最后,文章深入探讨了HA蛋白聚类与病毒感染的关系,模拟了24小时内HA聚类的动态变化,提供了从分子到细胞尺度的多尺度分析能力。 适合人群:具备生物学、物理学或工程学背景,对超分辨显微成像技术感兴趣的科研人员,尤其是从事细胞生物学、病毒学或光学成像研究的科学家和技术人员。 使用场景及目标:①理解和掌握scanSMLM技术的工作原理及其在三维超分辨成像中的应用;②学习如何通过Python代码实现完整的scanSMLM系统,包括硬件控制、图像采集、3D重建和数据分析;③应用于单分子水平研究细胞内结构和动态过程,如病毒入侵机制、蛋白质聚类等。 其他说明:本文提供的代码不仅实现了scanSMLM系统的完整工作流程,还涵盖了多种超分辨成像技术的模拟和比较,如STED、GSDIM等。此外,文章还强调了系统在硬件改动小、成像速度快等方面的优势,为研究人员提供了从理论到实践的全面指导。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值