`
manjingtou
  • 浏览: 119559 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

hibernate 查询效率(1)

阅读更多

相信越来越多的web开发者,在持久层都采用了hibernate。hibernate 可以大大提高开发效率,同时对应项目的移植也有好处,但是同样也存在问题,大家在使用hibernate的时候很少去关心效率问题,但是这个就是一个打的问题,好多项目不成功就是项目中没有对hibernate熟悉的人,大家就是会简单的使用,所以再有些细节上的东西我们开发人员没有注意。

 

   就拿hibernate来说吧,他支持hql查询,在我们组装sql语句时,需要注意几个问题:
   1、要查询当然离不开数据库,我们建表时,默认的主键都是索引,这里要注意的就是关于建立单个索引和复合索引了。

      具体的索引的hibernate中也是适用,我发现好多人用hibernate就很少提到索引这个概念了(用ibatis自己写sql就会关注索引字段,这个还是可以的额)

      索引的引用规则都是适用的:
      介绍下:单个索引就是出现索引字段作为条件就应用 ;
              复合索引(假设是2个字段的复合索引),出现复合索引的第一个字段作为条件就应用;
              出现复合索引的2个字段作为条件,这应用,如果没有出现复合索引的第一个字段则不应用;
      由此我们需要为我们的数据库建立索引,记住复合索引是有顺序的 。
     
      影响我们建立索引的条件还有就是业务(这个很重要) ,举个例子:如果有2个查询条件(性别、所在部门),倘若我们要建立符合索引,
      那么我们应该将"所在部门"字段放在前面,"性别"放在后面,主要是因为,如果某个地方的查询条件只有"所在部门",也可以起作用。另外要注意,如果查询索引字段参与函数计算和like等,那么索引也不起作用。
  2、 在我们写查询代码时,尽量对应各个表的已经存在索引写查询条件
      [第一个查询条件尽量是单个索引,或者是复合索引的第一个字段]  。
  3、还有就是大家再拼装查询语句时,传入的查询条件值尽量不要直接写在查询语句中,而是要以参数的方式提供即使用绑定参数
     这样,系统多次调用统一个查询时(比如:select * from TestVO where code = ?   [不要写为  select * from TestVO where code = 'aaaa']) ,
     条件值都是以参数的方式提供的,这样,多次查询虽然参数值不一样,但查询语句相同,数据库只有第一次才对查询语句进行编译,
     以后则不在编译,所以性能会有提升。
     用参数的方式还有一个好处是:如果你不是使用
     Criteria criteria = openSession().createCriteria(**PO.class);
     criteria.add(Restrictions.like( "name",convertDBString(name) ));
     的方式,而是使用hibernate的hql的话,那么如果参数值为中文会有问题,用参数可以解决这个问题。

注: 使用绑定参数的优势:
  我们为什么要使用绑定命名参数?任何一个事物的存在都是有其价

值的,具体到绑定参数对于HQL查询来说,主要有以下两个主要优势:
  ①、 可以利用数据库实施性能优化,因为对Hibernate来说在底层

使用的是PrepareStatement来完成查询,因此对于语法相同参数不同的

SQL语句,可以充分利用预编译SQL语句缓存,从而提升查询效率。
  ②、 可以防止SQL Injection安全漏洞的产生:

分享到:
评论

相关推荐

    论文研究-基于Hibernate的查询效率的探讨 .pdf

    基于Hibernate的查询效率的探讨,张文英,安伟莲,本文首先介绍了Hibernate的原理及查询机制,然后从制定合理的缓存策略和应用延迟加载两方面来提高Hibernate的查询效率。

    hibernate效率问题

    hibernate效率注意的几个问题,批量删除和批量更新建议用JDBC,这是一个原则,当然有的时候可能必须用Hibernate来批量更新和批量删除,那么这个时候我想说的就是,Hibernate批量更新和删除效率并非传说中的那么差,...

    基于Hibernate的效率查询的研究和应用.pdf

    基于Hibernate的效率查询的研究和应用.pdf............

    深入剖析hibernate的n+1问题和缓存问题

    深入理解hibernate的缓存问题和配置,提高使用hibernate的效率

    Hibernate3性能优化 Hibernate_regerence3.12

    有很多人认为Hibernate天生效率比较低,确实,在普遍情况下,需要将执行转换为SQL语句的 Hibernate 的效率低于直接JDBC存取,然而,在经过比较好的性能优化之后,Hibernate的性能还是让人相当满意的, 特别是应用二...

    Hibernate+中文文档

    1. Hibernate入门 1.1. 前言 1.2. 第一部分 - 第一个Hibernate应用程序 1.2.1. 第一个class 1.2.2. 映射文件 1.2.3. Hibernate配置 1.2.4. 用Ant构建 1.2.5. 启动和辅助类 1.2.6. 加载并存储对象 1.3. 第...

    让hibernate输出sql语句参数配置.doc

    为了提高 Hibernate 框架下的对象效率和开发效率,需要对其进行合理的配置。下面将详细介绍 Hibernate 配置参数的用途和使用方法。 1. hibernate.dialect hibernate.dialect 是一个 Hibernate Dialect 类名,允许 ...

    高效率spring+struts+hibernate分页算法

    高效率spring+struts+hibernate分页算法

    Hibernate中Criteria的完整用法

    Hibernate 中 Criteria 的完整用法 Hibernate 的 Criteria 是一种强大且灵活的查询机制,允许开发者根据需求灵活地组装查询条件。Criteria 的设计是基于 ...Criteria 的使用可以提高查询效率,降低开发难度。

    自动生成hibernate映射文件和实体类

    1. Hibernate 是一种开源的持久层框架,提供了一个高效的数据访问机制,能够将 Java 对象与数据库表进行映射。 2. MyEclipse 是一个集成开发环境(IDE),提供了丰富的开发工具和插件,包括数据库管理、代码编辑、...

    高效率的dw+spring+hibernate分页演示例子

    dwr+spring+hibernate分页演示例子.对dwr框架有兴趣可以参考参考。

    hibernate3.2中文文档(chm格式)

    1. Hibernate入门 1.1. 前言 1.2. 第一部分 - 第一个Hibernate应用程序 1.2.1. 第一个class 1.2.2. 映射文件 1.2.3. Hibernate配置 1.2.4. 用Ant构建 1.2.5. 启动和辅助类 1.2.6. 加载并存储对象 1.3. 第...

    HibernateAPI中文版.chm

    1. Hibernate入门 1.1. 前言 1.2. 第一部分 - 第一个Hibernate应用程序 1.2.1. 第一个class 1.2.2. 映射文件 1.2.3. Hibernate配置 1.2.4. 用Ant构建 1.2.5. 启动和辅助类 1.2.6. 加载并存储对象 1.3. 第...

    hibernate-4.1.4-final-API

    hibernate-4.1.4-final-API.chm 方便实用,支持索引,提高工作效率 与大伙分享

    hibernate4.0项目与hibernate4.0全套JAR包

    Hibernate是一个非常优秀的,成熟的ORM框架,可以在不用写SQL语句的情况下,仅仅对持久化对象进行操作便可以完成对数据库的操作,可以使开发者更为专注于业务代码的编写,提高了开发效率,相对于JDBC而言,大大简化...

    基于hibernate_mysql分页通用源码

    自己写的一个通用分页工具.是基于hibernate mysql struts2 写的.直接可以部署到tomcat 运行 欢迎指正

    hibernate 教程

    Hibernate查询语言(Query Language), 即HQL 11.1. 大小写敏感性(Case Sensitivity) 11.2. from 子句 11.3. 联合(Associations)和连接(joins) 11.4. select子句 11.5. 统计函数(Aggregate ...

    Hibernate_Tools_for_Eclipse插件的安装和使用

    使用 Hibernate_Tools_for_Eclipse 插件可以生成实体类、SQL语句等,提高开发效率。 三、 Hibernate Code Generation Hibernate Code Generation 是 Hibernate_Tools_for_Eclipse 插件的一部分,用于生成实体类、...

    Hibernate 中文 html 帮助文档

    1. Hibernate入门 1.1. 前言 1.2. 第一部分 - 第一个Hibernate应用程序 1.2.1. 第一个class 1.2.2. 映射文件 1.2.3. Hibernate配置 1.2.4. 用Ant构建 1.2.5. 启动和辅助类 1.2.6. 加载并存储对象 1.3. 第...

    Hibernate中文详细学习文档

    1. Hibernate入门 1.1. 前言 1.2. 第一部分 - 第一个Hibernate应用程序 1.2.1. 第一个class 1.2.2. 映射文件 1.2.3. Hibernate配置 1.2.4. 用Ant构建 1.2.5. 启动和辅助类 1.2.6. 加载并存储对象 1.3. 第...

Global site tag (gtag.js) - Google Analytics