(六完结)HQL_QBC查询详解--抓取策略优化机制

HQL_QBC查询详解–抓取策略优化机制
一、Hibernate 的查询方式:OID查询

OID检索:Hibernate根据对象的OID(主键)进行检索

  • 使用get方法

Customer customer = session.get(Customer.class,1l);

  • 使用load方法

Customer customer = session.load(Customer.class,1l);

二、Hibernate的查询方式:对象导航检索
LinkMan linkMan = session.get(LinkMan.class,1l);
Customer customer  = linkMan.getCustomer();

Customer customer = session.get(Customer.class,2l);
Set<LinkMan> linkMans = customer.getLinkMans();

三、Hibernate的查询方式:HQL检索

HQL查询:Hibernate Query Language,Hibernate的查询语言,是一种面向对象的方式的查询语言,语法类似SQL。通过session.createQuery(),用于接收一个HQL进行查询方式

1、初始化数据:

@Test
public void demo1() {
	Session session = HibernateUtils.getCurrentSession();
	Transaction tx = session.beginTransaction();
	//创建一个客户
	Customer customer = new Customer();
	customer.setCust_name("西风");
	for(int i =0;i<10;i++) {
		LinkMan linkMan = new LinkMan();
		linkMan.setLkm_name("王东"+i);
		linkMan.setCustomer(customer);
		
		customer.getLinkMans().add(linkMan);
		session.save(linkMan);
		
	}
	session.save(customer);
	
	tx.commit();
}
}

2、HQL的简单查询
在这里插入图片描述
3、HQL的别名查询
在这里插入图片描述
4、HQL的排序查询
在这里插入图片描述
5、HQL的条件查询
在这里插入图片描述
6、HQL的投影查询
投影查询:查询对象的某个或某些属性
在这里插入图片描述
7 HQL的分页查询
在这里插入图片描述
8 HQL的分组统计查询
在这里插入图片描述
9 HQL的多表查询
在这里插入图片描述

四、Hibernate的查询方式:QBC检索

1 简单查询
在这里插入图片描述
2 排序查询
在这里插入图片描述
4 条件查询
在这里插入图片描述
5 统计查询
在这里插入图片描述
6 离线条件查询(SSH)—DetachedCriteria
在这里插入图片描述

五、Hibernate的查询方式:SQL检索
Hibernate的抓取策略
延迟加载:

延迟加载:lazy(懒加载)。执行到该行代码的时候,不会发送语句去进行查询,在真正使用这个对象的属性的时候才会发送SQL语句进行查询

延迟加载的分类:

  • 类级别的延迟加载

指的是通过load方法查询某个对象的时候,是否采用延迟。
session.load(Customer.class,1l);

类级别延迟加载通过上的lazy进行配置,如果让lazy失效

  • 将lazy设置为false
  • 将持久化类使用final修饰
  • Hibernate. Initialize()
  • 关联级别的延迟加载
  • 指的是在查询到某个对象的时候,查询其关联的对象的时候,是否采用延迟加载。
    Customer customer = session.get(Customer.class,1l);
    customer.getLinkMans();----通过客户获得联系人的时候,联系人对象是否采用了延迟加载,称为是关联级别的延迟。
  • 抓取策略往往会和关联级别的延迟加载一起使用,优化语句。
抓取策略:

通过一个对象抓取到关联对象需要发送SQL语句,SQL语句如何发送,发送成什么样格式通过策略进行配置

  • 通过或者上通过fetch属性进行设置
  • fetch和这些标签上的lazy如何设置优化发送的SQL语句

1.上的fetch和lazy:

fetch:抓取策略,控制SQL语句格式

  • select :默认值,发送普通的select语句,查询关联对象
  • join :发送一条迫切左外连接查询关联对象
  • subselect :发送一条子查询查询其关联对象

lazy:延迟加载,控制查询关联对象的时候是否采用延迟

  • true :默认值,查询关联对象的时候,采用延迟加载
  • false :查询关联对象的时候,不采用延迟加载
    *extra :及其懒惰。

在实际开发中,一般都采用默认值。如果有特殊的需求,可能需要配置join

2.上的fetch和lazy:

fetch :抓取策略,控制SQL语句格式。

  • select :默认值,发送普通的select语句,查询关联对象。
  • join :发送一条迫切左外连接。

lazy :延迟加载,控制查询关联对象的时候是否采用延迟。

  • proxy :默认值,proxy具体的取值,取决于另一端的上的lazy的值。
  • false :查询关联对象,不采用延迟。
  • no-proxy :(不会使用)

在实际开发中,一般都采用默认值。如果有特殊的需求,可能需要配置join。

批量抓取:batch-size

一批关联对象一起抓取

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值