文档章节

Hibernate 性能优化法则

waylau
 waylau
发布于 2016/04/18 18:47
字数 1197
阅读 196
收藏 14
点赞 4
评论 0

原文同步至:http://waylau.com/tips-to-boost-your-hibernate-performance/


Hibernate 是 Java EE 应用中流行的 JPA 框架,简单易用,但很多使用过 Hibernate 的开发者都普遍反映 Hibernate 性能低下。究其原因,还是使用者没有对 Hibernate 进行过深入理解,对 Hibernate 的应用也只是浮于表面。本文介绍了几种简单实现 Hibernate 性能优化的方法。

启用 Hibernate 数据统计策略

没有测量就没有优化。启用 Hibernate 数据统计策略,用来做优化前后的数据对比。

hibernate.generate_statistics置为true,日志级别org.hibernate.stat置为DEBUG,Hibernate 会收集内部统计数据,比如查询的性能、缓存命中情况等。

做到这一步,你可以避免常见的问题,比如,查询缓慢,查询次数太多,缓存没有使用等情况。还有一点要注意,数据库的测试数据量大小对于查询结果影响也很大。

改进慢查询

慢查询并不是一个真正的 JPA 或 Hibernate 的问题。这种性能问题在每一个框架中都有可能发生,甚至是普通的 SQL 或者 JDBC,这时就需要在固定的 SQL 和数据库级别进行分析。如果你选择这样做了,那你就不能用 JPQL 或 Criteria API 来处理复杂或优化 SQL 查询。在这种情况下,需要使用本机查询来执行本地的SQL语句,在其中您可以使用所有 SQL 和专有的数据库功能。但是,这也有一个缺点。你得到是一个 Object[],而不是你从 JPQL 获得强类型的结果。您可以通过编程方式或通过@SqlResultSetMapping 注解映射到 Object[] 。

选择正确的 FetchType

使用错误的 FetchType 可能会导致在执行加载所需的实体时,查询数量巨大。

  • FetchType.LAZY:懒加载,加载一个实体时,定义懒加载的属性不会马上从数据库中加载。
  • FetchType.EAGER:急加载,加载一个实体时,定义急加载的属性会立即从数据库中加载。

比方 User 类有两个属性,name 跟 address,就像一般的系统,登录后用户名是需要在右上角显示出来的,此属性用到的几率极大,要马上到数据库查,用急加载;而用户地址大多数情况下不需要显示出来,只有在查看用户资料是才需要显示,需要用了才查数据库,用懒加载就好了。

所以,要正确的使用 FetchType。

使用特定的查询语句

当真正需要急加载时,可以使用特定的查询语句,比如用 FETCH JOIN 代替 JOINFETCH 会告诉 Hibernate 不单单是查询两个实体,还要把实体相关的实体从数据库查出来。

重量级操作交给数据库处理

Java 的处理逻辑能力并不一定比数据库本身的处理能力强,所以有些大数据集操作可以交给数据库处理。

使用缓存

在相同数据经常被读取的情况下,使用缓存来提高查询效率。

Hibernate 提供了三种缓存方式来组合使用。

  • 1st level cache(一级缓存):默认情况下是激活的,用来缓存在当前会话中使用的所有实体。
  • 2nd level cache(二级缓存):也可以存储实体,需要通过在 persistence.xml 设置shared-cache-mode属性。特定实体的高速缓存可以通过在实体上添加javax.persistence.Cacheableorg.hibernate.annotations.Cache 注解来实现。
  • query cache(查询缓存):不存储实体。它缓存查询结果,并且只包含实体引用和标量值。你需要通过在 persistence.xml 文件中设置hibernate.cache.use_query_cache 属性和 Query 的 cacheable 属性来激活该缓存。

在更新和删除时使用批量处理

JPA 2.1 新增了 CriteriaUpdateCriteriaDelete 接口。

  • CriteriaUpdate 接口定义用于使用 Criteria API 批量更新的操作功能。该批量更新操作直接映射到数据库的更新操作,会绕过任何乐观锁检查。
  • CriteriaDelete 接口定义用于使用 Criteria API 批量删除的操作功能。该批量删除操作直接映射到数据库的删除操作。持久化上下文不会同步批量删除的结果。

参考引用

© 著作权归作者所有

共有 人打赏支持
waylau

waylau

粉丝 466
博文 82
码字总数 157652
作品 2
深圳
架构师
扼杀性能的 10 个常见 Hibernate 错误

医疗类app开发 ¥11000 微信二次开发 ¥3500 抽奖活动前端开发 ¥7000 官网UI设计 ¥4000 搜索匹配方案 ¥25000 艺术品交易网站开发 ¥80000 本文由码农网 – 小峰原创翻译,转载请看清文末的...

抽奖活动前端开发 ¥7000 ⋅ 2017/12/29 ⋅ 0

Hernate的优化方案

【IT168 技术文档】 一、批量修改和删除 在Hibernate 2中,如果需要对任何数据进行修改和删除操作,都需要先执行查询操作,在得到要修改或者删除的数据后,再对该数据进行相应的操作处理。在...

晨曦之光 ⋅ 2012/03/09 ⋅ 0

Hibernate性能优化

在进行Hibernate性能优化时,需要从以下几个方面进行考虑: ◆数据库设计调整。 ◆HQL优化。 ◆API的正确使用(如根据不同的业务类型选用不同的集合及查询API)。 ◆主配置参数(日志、查询缓存...

Kerry_Han ⋅ 2013/08/30 ⋅ 0

Hibernate中Session.load与Session.get的区别 - [Hibern...

Session.load/get方法均可以根据指定的实体类和id从数据库读取记录,并返回与之对应的实体对象。 其区别在于: 如果未能发现符合条件的记录,get方法返回null,而load方法会抛出一个ObjectN...

小梅菜鸟 ⋅ 2012/06/01 ⋅ 0

PHP 开发中的外围资源性能分析(二)

上一篇中我们分析了后端外围资源中 IO 操作和中间件服务对整个 PHP Web 应用体验的影响。今天我们分析数据库给整个应用性能带来的影响。 数据库 首先直观地看两张图,一张是来自 OneAPM 后台...

OneAPM蓝海讯通 ⋅ 2015/10/10 ⋅ 0

读《面向程序员的数据库访问性能优化法则》

刚刚看了一下2014年中国数据库技术大会(DTCC)PPT,网易杭州研究院的一位同学介绍了一下数据库的优化与调优。 网易的Mysql优化做的很好,而且还写了本书和大家分享这些经验《深入浅出MySQL...

ifeixiang ⋅ 2015/01/04 ⋅ 0

Hibernate OGM 4.1.0.Beta8 发布,性能提升

Hibernate OGM 4.1.0.Beta8 发布,此版本提升了性能,减少了数据往返存储,优化数据存储的乐观锁支持,提供原子性的 find-and-update 操作。 此版本同时也解决了一些 bug,还有一些 hood 下的...

叶秀兰 ⋅ 2014/10/31 ⋅ 8

Spring/Hibernate 应用性能优化的7种方法

对于大多数典型的 Spring/Hibernate 企业应用而言,其性能表现几乎完全依赖于持久层的性能。此篇文章中将介绍如何确认应用是否受数据库约束,同时介绍七种常用的提高应用性能的速成法。本文系...

OneAPM蓝海讯通 ⋅ 2015/10/27 ⋅ 0

程序员数据库访问的优化的一些思考

一、数据库访问优化的五个法则 在实际开发,我们主要是需要对SQL语句进行优化,我们需要快速定位能性的瓶颈点,也就是说快速找到我们SQL主要的开销在哪里?根据木桶原理可以知道,最慢的设备...

BravoZu ⋅ 2014/03/04 ⋅ 0

Hibernate中Session.load与Session.get的区别

Session.load/get方法均可以根据指定的实体类和id从数据库读取记录,并返回与之对应的实体对象。 其区别在于: 如果未能发现符合条件的记录,get方法返回null,而load方法会抛出一个ObjectN...

疯狂的艺术家 ⋅ 2011/06/12 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

2018上海云栖大会workshop-日志数据采集与分析对接

摘要: 日志数据采集与分析对接 课程描述 通过日志服务采集用户、数据库、业务等访问数据。演示对于业务日志分析与处理,程序日志查询与监控,打通日志与数据仓库对接案例。 日志种类 网站访...

猫耳m ⋅ 24分钟前 ⋅ 0

SpringMVC中的ContentNegotiatingViewResolver配置

pom.xml <properties><commons-lang.version>2.6</commons-lang.version><slf4j.version>1.7.6</slf4j.version><spring.version>4.1.3.RELEASE</spring.version> <jack......

颖伙虫 ⋅ 26分钟前 ⋅ 0

Spring Boot 2.0正式发布,升还是不升呢?

Spring几乎是每一位Java开发人员都耳熟能详的开发框架,不论您是一名初出茅庐的程序员还是经验丰富的老司机,都会对其有一定的了解或使用经验。在现代企业级应用架构中,Spring技术栈几乎成为...

java高级架构牛人 ⋅ 27分钟前 ⋅ 0

打包时隐藏打印日志

1.打包时不允许项目中有打印的日志,可以在pch中加入下面这段代码即可 #ifdef DEBUG# define Log(fmt, ...) NSLog((@"%s [Line %d] " fmt), __PRETTY_FUNCTION__, __LINE__, ##__VA...

小黑202 ⋅ 28分钟前 ⋅ 0

SSL双向认证的实现

环境 系统:archlinux/centOS nginx:nginx/1.12.2 浏览器:火狐firefox 前提:1.安装nginx。    2.安装openssl。 生成证书 新建工作目录  首先建立一个工作目录,这里以我的工作目录为例...

颖辉小居 ⋅ 34分钟前 ⋅ 0

vscode 代码格式化,语法检查插件ESLint+Prettier

ESLint+Prettier prettier只关注格式化 ,插件prettier-vscode,编辑器的配置setting.json会出现prettier插件的相关配置节点,同时也能看到一些默认的配置信息。 安装成功后,编辑器默认的格式...

momo1987 ⋅ 37分钟前 ⋅ 0

使用TinyProxy搭建代理服务器

什么是TinyProxy 它是一个代理服务器,用来实现http或https代理,windows系统一直在用ccproxy, 非windows系统,怎么开放个http代理呢?那就是TinyProxy。 安装 直接执行命令即可 sudo apt-g...

bengozhong ⋅ 37分钟前 ⋅ 0

掌握需求过程

1,需求必须可度量、可测试 2,需求是什么? 功能需求 非功能需求 限制条件 3,Volere需求过程 采用Volere需求过程,最好采用RUP,增量,迭代,螺旋,Scrum或其他类似的迭代式开发过程 (注意...

霜叶情 ⋅ 41分钟前 ⋅ 0

分布式微服务云架构开发Web应用

举一个简单的例子,在快速入门工程的基础上,举一个简单的示例来通过Thymeleaf渲染一个页面。 @Controller public class HelloController { @RequestMapping("/") pub...

明理萝 ⋅ 43分钟前 ⋅ 0

图应用之关键路径(Critical Path)

之前我们介绍过,在一个工程中我们关心两个问题: (1)工程是否顺利进行 (2)整个工程最短时间。 之前我们优先关心的是顶点(AOV),同样我们也可以优先关心边(同理有AOE)。(Activity ...

临江仙卜算子 ⋅ 44分钟前 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部