相信越来越多的web开发者,在持久层都采用了hibernate。都说hibernate效率高,可是当整个项目下来后发现,比其他持久层版本慢很多,当然功能也多很多。记得当初同事测试hibernate销率时,在100万数据量的情况下,hibernate的效率几乎接近于jdbc,那么为什么如今很多公司的项目运行那么慢呢(不仅仅是hibernate),也许有些细节上的东西我们开发人员没有注意。
就拿hibernate来说吧,他支持hql查询,在我们组装sql语句时,需要注意2个问题:
1、要查询当然离不开数据库,我们建表时,默认的主键都是索引,这里要注意的就是关于建立单个索引和复合索引了。
介绍下:单个索引就是出现索引字段作为条件就应用 ;
复合索引(假设是2个字段的复合索引),出现复合索引的第一个字段作为条件就应用;
出现复合索引的2个字段作为条件,这应用,如果没有出现复合索引的第一个字段则不应用;
由此我们需要为我们的数据库建立索引,记住复合索引是有顺序的 。
影响我们建立索引的条件还有就是业务(这个很重要) ,举个例子:如果有2个查询条件(性别、所在部门),倘若我们要建立符合索引,
那么我们应该将"所在部门"字段放在前面,"性别"放在后面,主要是因为,如果某个地方的查询条件只有"所在部门",也可以起作用。另外要注意,如果查询索引字段参与函数计算和like等,那么索引也不起作用。
2、 在我们写查询代码时,尽量对应各个表的已经存在索引写查询条件,
[第一个查询条件尽量是单个索引,或者是复合索引的第一个字段] 。
3、还有就是大家再拼装查询语句时,传入的查询条件值尽量不要直接写在查询语句中,而是要以参数的方式提供,这样,系统多次调用统一个查询时(比如:select * from employee where code = ? [不要写为 select * from employee where code = 'aaaa']) ,
条件值都是以参数的方式提供的,这样,多次查询虽然参数值不一样,但查询语句相同,数据库只有第一次才对查询语句进行编译,以后则不在编译,所以性能会有提升。(这告诉我们,现实性hql或sql时,尽量写成统一形式,只有参数不同,用时再传进去)
用参数的方式还有一个好处是:如果你不是使用
Criteria criteria = openSession().createCriteria(**PO.class);
criteria.add(Restrictions.like( "name",convertDBString(name) ));
的方式,而是使用hibernate的hql的话,那么如果参数值为中文会有问题,用参数可以解决这个问题。
分享到:
相关推荐
hibernate效率注意的几个问题,批量删除和批量更新建议用JDBC,这是一个原则,当然有的时候可能必须用Hibernate来批量更新和批量删除,那么这个时候我想说的就是,Hibernate批量更新和删除效率并非传说中的那么差,...
根据提供的文件信息,我们可以深入探讨Hibernate中的连表查询方法及其应用。下面将详细介绍与标题、描述及部分代码相关的...需要注意的是,在编写连表查询时要充分考虑性能问题,避免因查询复杂度过高而导致性能瓶颈。
本篇文章将深入探讨如何使用Hibernate实现模糊查询和分页功能,这对于任何需要处理大量数据的应用程序来说都是至关重要的技能。 首先,让我们了解Hibernate的核心概念。Hibernate是一个开源的JPA(Java Persistence...
在大数据量处理场景下,分页查询是提高数据检索效率的重要手段之一。Hibernate作为Java领域内最常用的持久层框架之一,其内置的分页功能非常实用且高效。本文将深入探讨Hibernate如何实现分页查询,并分析不同数据库...
相比静态SQL,动态SQL更加灵活,能够适应复杂多变的查询需求,避免了硬编码SQL带来的问题,如代码冗余、难以维护等。 三、Hibernate中的动态SQL 在Hibernate中,我们通常使用HQL(Hibernate Query Language)或...
【hibernate查询详解】 Hibernate,作为一款强大的Java对象关系映射(ORM)框架,极大地简化了数据库操作。它允许开发者使用面向对象的方式来处理数据库,从而避免了传统的JDBC编码方式带来的复杂性。本篇文章将...
在Java的持久化框架中,Hibernate是一个非常重要的工具,它提供了强大的对象关系映射(ORM)功能,使得开发者可以方便地在Java对象和数据库表之间...在实际开发中,合理利用本地SQL查询,能有效提高效率,优化性能。
在Java企业级开发中,Hibernate是一个非常重要的对象关系映射(ORM)框架,它极大地简化了数据库操作。...希望这份"JavaEE学习笔记之Hibernate的MySql查询.doc"文档能帮助你更深入地理解并运用这些技术。
本文将深入探讨如何使用Hibernate实现递归查询,以解决在数据层次结构中涉及父节点与子节点关系时的问题。递归查询通常用于处理树形结构的数据,例如组织结构、菜单系统或者文件目录等。 首先,我们需要了解递归的...
在Java的持久化框架中,Hibernate是一个非常重要的工具,它提供了ORM(对象关系映射)功能,使得开发者能够更方便地操作数据库。...正确理解和使用Hibernate,能够大大提高Java开发中的数据库操作效率。
当我们需要进行更复杂的数据库查询时,Hibernate提供了丰富的高级查询功能,这正是“Hibernate的高级查询”这一主题的核心所在。 在Hibernate中,高级查询主要包括HQL(Hibernate Query Language)、Criteria API和...
Hibernate的自定义查询能力极大地提高了开发效率,通过HQL、命名查询、Criteria API和直接SQL查询,我们可以根据项目需求选择最合适的方式来处理数据。`QueryDAO`和`QueryNamedDAO`的实现细节可能包含了对这些查询...
此外,优化查询,避免N+1查询问题,合理设计实体关系,都能有效提升Hibernate分页查询的效率。 总结起来,Hibernate的分页查询和数据库连接管理是其强大功能的重要组成部分。正确理解和使用这些特性,能够帮助...
Hibernate的多态查询是其强大功能之一,它允许我们在处理复杂业务逻辑时保持代码的简洁和可维护性。理解并熟练掌握这一特性,对于提升Java EE项目的开发效率和质量具有重要意义。通过阅读提供的文档“Hibernate映射...
“Hibernate 级联查询”是指在使用Hibernate这个Java持久化框架时,如何处理对象之间的关联查询。Hibernate提供了级联操作来简化数据的保存、更新和删除等操作,使得开发者无需手动编写复杂的SQL语句,就能实现关联...
在Java的持久化框架Hibernate中,查询是连接应用程序与数据库的关键环节。Hibernate提供了两种主要的查询方式:离线查询(Criteria API...理解并熟练掌握这两种查询方式,将有助于提升Hibernate的使用效率和代码质量。
**正文** Hibernate是一款强大的Java持久化框架,它简化了数据库...了解并熟练掌握这些查询技术,将极大地提高开发效率,减少与数据库交互中的错误。希望这篇文章能帮助你更好地理解和使用Hibernate进行数据库查询。
通过 Hibernate,开发者可以避免编写大量的 SQL 代码,提高开发效率。 **多表连接查询** 在实际业务中,往往需要处理多个关联表的数据。Hibernate 支持多种方式来实现多表连接查询,包括 HQL(Hibernate Query ...