热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Hibernate抓取策略与检索配置详解

本文详细介绍了Hibernate中的立即检索与延迟检索的概念及区别,同时探讨了类级别与关联级别的检索配置方法。通过具体的配置示例,帮助开发者更好地理解和应用这些策略。

1. 立即检索与延迟检索的区别


1.1 立即检索


在执行特定代码时,系统会立即触发SQL查询操作。最典型的例子是使用get()方法,该方法会直接从数据库中加载实体数据。


1.2 延迟检索


与立即检索不同,延迟检索在执行代码时并不会立刻发送SQL查询。相反,它会在实际需要数据时才进行查询,从而提高性能。常用的实现方式是通过load()方法。


2. 类级别与关联级别的检索配置


2.1 类级别的检索配置


类级别的检索配置通常在映射文件的class标签中设置lazy属性,用于控制整个类的加载行为。


2.2 关联级别的检索配置


关联级别的检索配置则是在关联映射(如setmany-to-one)中设置lazy属性,以控制关联对象的加载策略。


3. 具体配置示例


3.1 从一方关联多方


* <set>
* fetch: 控制SQL语句的类型
* join: 发送迫切左外连接的SQL查询关联对象。如果fetch="join",则lazy属性将被忽略。
* select: 默认值,发送多条SQL查询关联对象。
* subselect: 发送子查询查询关联对象。(需使用Query接口测试)
* lazy: 控制关联对象的检索是否采用延迟
* true: 默认值,查询关联对象时使用延迟检索
* false: 查询关联对象时不使用延迟检索
* extra: 极其懒惰。如果fetchjoin的情况,则lazy属性将被忽略。

3.2 从多方关联一方


* <many-to-one>
* fetch: 控制SQL语句的发送格式
* join: 发送一个迫切左外连接查询关联对象。如果fetch="join",则lazy属性将被忽略。
* select: 发送多条SQL检索关联对象
* lazy: 控制关联对象检索时是否采用延迟
* false: 不延迟
* proxy: 使用代理。检索订单时,是否立即检索客户由Customer对象的映射文件中class标签上的lazy属性决定。
* no-proxy: 不使用代理

推荐阅读
  • 包含phppdoerrorcode的词条 ... [详细]
  • 本文详细探讨了在Web开发中常见的UTF-8编码问题及其解决方案,包括HTML页面、PHP脚本、MySQL数据库以及JavaScript和Flash应用中的乱码问题。 ... [详细]
  • PHP面试题精选及答案解析
    本文精选了新浪PHP笔试题及最新的PHP面试题,并提供了详细的答案解析,帮助求职者更好地准备PHP相关的面试。 ... [详细]
  • SQL Server 存储过程实践任务(第二部分)
    本文档详细介绍了三个SQL Server存储过程的创建与使用方法,包括统计特定类型客房的入住人数、根据房间号查询客房详情以及删除特定类型的客房记录。 ... [详细]
  • 本文探讨了在某些情况下,为何需要将完整的PHP代码分成多个部分编写。通过示例代码和详细解释,帮助读者理解这种做法的好处。 ... [详细]
  • 在运行于MS SQL Server 2005的.NET 2.0 Web应用中,我偶尔会遇到令人头疼的SQL死锁问题。过去,我们主要通过调整查询来解决这些问题,但这既耗时又不可靠。我希望能找到一种确定性的查询模式,确保从设计上彻底避免SQL死锁。 ... [详细]
  • 周排行与月排行榜开发总结
    本文详细介绍了如何在PHP中实现周排行和月排行榜的开发,包括数据库设计、数据记录和查询方法。涉及的知识点包括MySQL的GROUP BY、WEEK和MONTH函数。 ... [详细]
  • importpymysql#一、直接连接mysql数据库'''coonpymysql.connect(host'192.168.*.*',u ... [详细]
  • 本文详细介绍了MySQL数据库的基础语法与核心操作,涵盖从基础概念到具体应用的多个方面。首先,文章从基础知识入手,逐步深入到创建和修改数据表的操作。接着,详细讲解了如何进行数据的插入、更新与删除。在查询部分,不仅介绍了DISTINCT和LIMIT的使用方法,还探讨了排序、过滤和通配符的应用。此外,文章还涵盖了计算字段以及多种函数的使用,包括文本处理、日期和时间处理及数值处理等。通过这些内容,读者可以全面掌握MySQL数据库的核心操作技巧。 ... [详细]
  • Django与Python及其他Web框架的对比
    本文详细介绍了Django与其他Python Web框架(如Flask和Tornado)的区别,并探讨了Django的基本使用方法及与其他语言(如PHP)的比较。 ... [详细]
  • GreenPlum采纳ShareNothing的架构,良好的施展了便宜PC的作用。自此IO不在是DW(datawarehouse)的瓶颈,相同网络的压力会大很多。然而GreenPlum的查问优化策略可能防止尽量少的网络替换。对于首次接触GreenPlum的人来说,必定耳目一新。 ... [详细]
  • 关于进程的复习:#管道#数据的共享Managerdictlist#进程池#cpu个数1#retmap(func,iterable)#异步自带close和join#所有 ... [详细]
  • 本文介绍了如何使用Python爬取妙笔阁小说网仙侠系列中所有小说的信息,并将其保存为TXT和CSV格式。主要内容包括如何构造请求头以避免被网站封禁,以及如何利用XPath解析HTML并提取所需信息。 ... [详细]
  • 本文详细介绍了 com.apollographql.apollo.api.internal.Optional 类中的 orNull() 方法,并提供了多个实际代码示例,帮助开发者更好地理解和使用该方法。 ... [详细]
  • 在将Excel数据导入MySQL数据库的过程中,如何确保不会生成重复记录?本文介绍了一种方法,通过PHP脚本检查数据库中是否存在相同的“Code”字段值,从而避免重复记录的产生。该方法不仅提高了数据导入的准确性,还增强了系统的健壮性。 ... [详细]
author-avatar
苗淑香哈哈_405_408
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有