前言

  老平台的查询速度很慢,需要进行优化(...说白了就是优化sql语句),老平台用的strus2+hibernate框架,查询基本都是使用的HSQL。

关于hsql

  HQL是Hibernate Query Language即Hibernate查询语言

  优点:

    不需要再编写繁复的SQL 语句,针对实体类及其属性进行查询

   查询结果是直接存放在List 中的对象,不需要再次封装

  独立于数据库(针对不同数据库进行查询,跨数据库,Mysql->Oracle),

   对不同的数据库根据Hibernate dialect 属性的配置自动生成不同的SQL 语句执行

  缺点:

    涉及到复杂的sql或者数据量大的情况,不好优化

  

例子

  我的项目里就是一张单表的分页查询,一共2百多万条数据。(oracle数据库)

下面是sql分页查询时打印出来的原生sql是这样的。。

     select
*
from
( select
row_.*,
rownum rownum_
from
( select
tblmerinfo0_.MER_CODE as MER1_19_,
tblmerinfo0_.MER_NAME as MER2_19_,
tblmerinfo0_.MER_SHORT_NAME as MER3_19_,
tblmerinfo0_.MER_CITY as MER4_19_,
tblmerinfo0_.MER_NATION as MER5_19_,
tblmerinfo0_.MER_STATUS as MER6_19_,
tblmerinfo0_.MER_ACQ_CODE as MER7_19_,
tblmerinfo0_.MER_TYPE as MER8_19_,
tblmerinfo0_.MER_WARNING_AMT as MER9_19_,
tblmerinfo0_.MER_GROUP_ID as MER10_19_,
tblmerinfo0_.MER_COMMISION_TYPE as MER11_19_,
tblmerinfo0_.MER_COMMISION_VALUE as MER12_19_,
tblmerinfo0_.MER_TRANS_CURR as MER13_19_,
tblmerinfo0_.MER_SETT_CURR as MER14_19_,
tblmerinfo0_.MER_SETT_ACCT_NAME as MER15_19_,
tblmerinfo0_.MER_SETT_ACCT as MER16_19_,
tblmerinfo0_.MER_CB_CODE as MER17_19_,
tblmerinfo0_.MER_CB_NAME as MER18_19_,
tblmerinfo0_.MER_CORP as MER19_19_,
tblmerinfo0_.MER_MASTER as MER20_19_,
tblmerinfo0_.MER_REL_MAN as MER21_19_,
tblmerinfo0_.MER_REL_TEL as MER22_19_,
tblmerinfo0_.MER_FAX as MER23_19_,
tblmerinfo0_.MER_EMAIL as MER24_19_,
tblmerinfo0_.MER_ADDR as MER25_19_,
tblmerinfo0_.MER_POSTCODE as MER26_19_,
tblmerinfo0_.MER_PASSWORD as MER27_19_,
tblmerinfo0_.PASSWORD_INITIAL_VAL as PASSWOR28_19_,
tblmerinfo0_.PASSWORD_EXPIRED_DATE as PASSWOR29_19_,
tblmerinfo0_.PASSWORD_EXPIRED as PASSWOR30_19_,
tblmerinfo0_.BATCH_NO as BATCH31_19_,
tblmerinfo0_.REC_CREATE_TM as REC32_19_,
tblmerinfo0_.REC_UPDATE_TM as REC33_19_,
tblmerinfo0_.MER_OPEN_TM as MER34_19_,
tblmerinfo0_.MER_CLOSE_TM as MER35_19_,
tblmerinfo0_.MER_DAY_LIMIT as MER36_19_,
tblmerinfo0_.MER_SINGLE_LIMIT as MER37_19_,
tblmerinfo0_.SUPPORT_BRAND_FLAG as SUPPORT38_19_,
tblmerinfo0_.ROUTE_SCHEME as ROUTE39_19_,
tblmerinfo0_.BATCH_SETT_POINT as BATCH40_19_,
tblmerinfo0_.DELAY_SETT_DAYS as DELAY41_19_,
tblmerinfo0_.DCC_FLAG as DCC42_19_,
tblmerinfo0_.SUPPORT_FUNC_FLAG as SUPPORT43_19_,
tblmerinfo0_.CITY_CODE as CITY44_19_,
tblmerinfo0_.SUPPORT_DCC_FLAG as SUPPORT45_19_
from
SWTONLINE.TBL_MER_INFO tblmerinfo0_
order by
tblmerinfo0_.MER_CODE ) row_ )
where
rownum_ <= 24
and rownum_ > 12

执行时间:63s

个人分析了一下慢的原因:里层的查询像是查询了所有,然后外层的查询在分页。仅个人观点。如果有大神看到这里有不同的看法欢迎指出

下面是我个人的原生sql:

 select * from
(
select a.*, rownum r from

select * from tbl_mer_info where 1=1 order by mer_code
) a where rownum <= 24
) b where b.r > 12

执行时间:0.2s

个人分析:与上面的sql不同就是我的rownum先查询的<=24,然后外层在>12,这样会大大提交效率

写到这里,不禁就开始比较hibernate与mybatis的各自优点,个人觉得还是mybatis好,够灵活。虽然hibernate针对各个数据库设定了"方言",号称兼容性好,可是谁会在开发的过程中替换数据库呢?

hibernate的面向对象查询的效率有多低?的更多相关文章

  1. Criteria——Hibernate的面向对象查询

    提到Hibernate的查询.我们往往会想到HQL,他使我们的SQL语句面向对象话. 事实上细看,差点儿相同就是把SQL语句中的表和字段用所相应的实体和属性给取代了.事实上.Hibernate中还有还 ...

  2. Hibernate(五)——面向对象查询语言和锁

    Hibernate做了数据库中表和我们实体类的映射,使我们不必再编写sql语言了.但是有时候查询的特殊性,还是需要我们手动来写查询语句呢,Hibernate框架为了解决这个问题给我们提供了HQL(Hi ...

  3. Hibernate Query Language查询:

    Hibernate Query Language查询: Criteria查询对查询条件进行了面向对象封装,符合编程人员的思维方式,不过HQL(Hibernate Query Language)查询提供 ...

  4. hibernate的hql查询

    1.概念介绍 1.Query是Hibernate的查询接口,用于从数据存储源查询对象及控制执行查询的过程,Query包装了一个HQL查询语句. 2.HQL是Hibernate Query Langua ...

  5. Hibernate之HQL查询

    一.Hibernate 提供了以下几种检索对象的方式: 导航对象图检索方式: 根据已经加载的对象导航到其他对象 OID 检索方式: 按照对象的 OID 来检索对象 HQL 检索方式:使用面向对象的 H ...

  6. Hibernate五 HQL查询

    HQL查询一 介绍1.HQL:Hibernate Query Language,是一种完全面向对象的查询语言.使用Hibernate有多重查询方式可供选择:hibernate的HQL查询,也可以使用条 ...

  7. Hibernate(九)HQL查询

    一.Hibernate提供的查询方式 OID查询方式:主键查询.通过get()或者load()方法加载指定OID的对象查询结果为一个 HQL查询方式:通过Query接口使用HQL语言进行查询 QBC查 ...

  8. 框架之 hibernate之各种查询

    1. Hibernate的查询方式 2. Hibernate的查询策略 案例:使用Hibernate完成查询所有联系人功能 需求分析 1. 完成所有的联系人的查询 技术分析之Hibernate框架的查 ...

  9. Hibernate框架的查询方式

    技术分析之Hibernate框架的查询方式        1. 唯一标识OID的检索方式        * session.get(对象.class,OID)    2. 对象的导航的方式       ...

随机推荐

  1. 84、PullToRefresh使用详解

    PullToRefresh使用详解(一)--构建下拉刷新的listView http://blog.csdn.net/harvic880925/article/details/17680305 Pul ...

  2. PE导入表分析

    A.dll 导入 B.dll 导出函数 A.dll 表内容 这个结构指向的B导出函数的地址 Hook这个位置 等同于 Hook B.dll导出函数

  3. Tiny4412 Android 5.0 编译系统学习笔记

    1.Android 编译系统概述 Build 系统中最主要的处理逻辑都在 Make 文件中,而其他的脚本文件只是起到一些辅助作用. 整个 Build 系统中的 Make 文件可以分为三类: ① Bui ...

  4. 【BZOJ4002】[JLOI2015]有意义的字符串 数学

    [BZOJ4002][JLOI2015]有意义的字符串 Description B 君有两个好朋友,他们叫宁宁和冉冉.有一天,冉冉遇到了一个有趣的题目:输入 b;d;n,求 Input 一行三个整数 ...

  5. How to install sharepoint server 2010 sp2 in window 7 x64

    1. 下载 sharepoint server 2010 sp2 x64 2. 下载 前置环境插件 Microsoft FilterPack 2.0  (CD "C:\Program Fil ...

  6. Struts2使用struts标签判断变量是否为空的写法

    <%@taglib uri="/struts-tags" prefix="s"%> <span id="viewOrgName&qu ...

  7. DK NIO的BUG,例如臭名昭著的epoll bug,它会导致Selector空轮询,最终导致CPU 100%。

    NIO的epoll空轮询bug - Lost blog - 博客园 https://www.cnblogs.com/JAYIT/p/8241634.html NIO的epoll空轮询bug   JDK ...

  8. rabbitmq延迟队列相关

    https://blog.csdn.net/qq_26656329/article/details/77891793        --------------rabbitmq queue_decla ...

  9. matrix---简单dp,边界边界-_-

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5569 简单dp,恶心的边界处理,无语: if((i+j)%2==1) dp[i][j]=a[i-1][ ...

  10. rabbitMQ 安装,集群搭建, 编码

    RabbitMQ 一.背景 命令行工具: http://www.rabbitmq.com/man/rabbitmqctl.1.man.html 介绍入门文章: http://blog.csdn.net ...