Hibernate之查询效率问题

原创 2006年05月31日 14:20:00

      相信越来越多的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']) ,
     条件值都是以参数的方式提供的,这样,多次查询虽然参数值不一样,但查询语句相同,数据库只有第一次才对查询语句进行编译,
     以后则不在编译,所以性能会有提升。
     用参数的方式还有一个好处是:如果你不是使用
     Criteria criteria = openSession().createCriteria(**PO.class);
     criteria.add(Restrictions.like( "name",convertDBString(name) ));
     的方式,而是使用hibernate的hql的话,那么如果参数值为中文会有问题,用参数可以解决这个问题。

Hibernate查询的各种方式效率比较

查询已知表名的实体时推荐使用getHibernateTemplate().executeWithNativeSession() + SQLQuery方式。 以下测试使用JUnit进行,仅查询一次,查询...
  • zhouxianli
  • zhouxianli
  • 2010年01月25日 10:56
  • 7832

Hibernate查询性能优化技巧

数据库查询性能的提升也是涉及到开发中的各个阶段,在开发中选用正确的查询方法无疑是最基础也最简单的。 SQL语句的优化        使用正确的SQL语句可以在很大程度上提高系统的查询性...
  • he90227
  • he90227
  • 2014年07月23日 13:53
  • 5549

hibernate单表查询总结(下)

hibernate单表查询总结(下) 本博客接着hibernate单表查询总结(上)继续就Hibernate的单表查询进行总结一、分页查询public void testQuerySingleTab...
  • leisure_life
  • leisure_life
  • 2017年03月10日 15:38
  • 224

Hibernate之查询效率问题

相信越来越多的web开发者,在持久层都采用了hibernate。都说hibernate效率高,可是当整个项目下来后发现,比 其他持久层版本慢很多,当然功能也多很多。记得当初同事测试hibernate...
  • frankaqi
  • frankaqi
  • 2014年07月10日 17:54
  • 909

Hibernate查询优化 HQL提高效率

1、Hibernate查询性能优化 1、1
  • wodestudy
  • wodestudy
  • 2014年04月11日 21:26
  • 9799

Hibernate之查询效率问题

      相信越来越多的web开发者,在持久层都采用了hibernate。都说hibernate效率高,可是当整个项目下来后发现,比其他持久层版本慢很多,当然功能也多很多。记得当初同事测试hiber...
  • CharlesYY
  • CharlesYY
  • 2006年05月31日 14:20
  • 10055

hibernate多表操作之多对多

一对多描述的是对象与集合的关系或者对象与对象之间的关系。 更准确的说:一对多描述的对象与集合之间的关系 即:在Classes类中set集合属性,多对一描述的是对象与对象的关系,即:在Student类中...
  • l7945685
  • l7945685
  • 2016年08月26日 20:11
  • 2632

Hibernate之查询效率问题(转)

第一:Hibernate作为ORM,有一个ORM固有的问题,就是由于为了持久对象的同步,不能够使用批量删除和批量更新的sql,只能按照主键一条条来操作。因此效率相对JDBC来说是比较低的。然而事情也并...
  • virgoboy2004
  • virgoboy2004
  • 2009年07月28日 09:38
  • 2475

hibernate底层的分页如何提高查询速度?

待完成
  • u010523770
  • u010523770
  • 2016年11月10日 17:23
  • 229

Hibernate性能优化

1.深入Hibernate 一、Hibernate数据查询 HQL:Hibernate查询语言,它是Hibernate提供的一种面向对象的查询语言。  (1)在查询语句中设定各种查询...
  • he90227
  • he90227
  • 2014年07月28日 13:54
  • 3199
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Hibernate之查询效率问题
举报原因:
原因补充:

(最多只允许输入30个字)