前言

  老平台的查询速度很慢,需要进行优化(...说白了就是优化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. UIWindow和UIScreen

    UIWindow和UIScreen 目录 概述 职责 实用操作 概述 UIWindow职责 包含了应用程序的可视化的内容 为视图和其他应用程序对象在触摸事件中提供了关键性的作用 与视图控制器一起协作来 ...

  2. 160229-02、Sublime Text 3 快捷键总结

    选择类 Ctrl+D 选中光标所占的文本,继续操作则会选中下一个相同的文本. Alt+F3 选中文本按下快捷键,即可一次性选择全部的相同文本进行同时编辑.举个栗子:快速选中并更改所有相同的变量名.函数 ...

  3. 160428、JavaScript知识总结—cookie及其应用

    一.cookie基本介绍 cookie是document的对象.cookie可以使得JavaScript代码能够在用户的硬盘上持久地存储数据,并且能够获得以这种方式存储的数据.cookie还可以用于客 ...

  4. hibernate的二级缓存----collection和query的二级缓存

    collection二级缓存: 不使用集合的二级缓存时: 运行下面的代码: @Test public void testCollectionSecondLevelCache1(){ Departmen ...

  5. Python resources

    我想很多程序员应该记得 GitHub 上有一个 Awesome - XXX 系列的资源整理.awesome-python 是 vinta 发起维护的 Python 资源列表,内容包括:Web框架.网络 ...

  6. Exception in thread "main" java.lang.UnsupportedClassVersionError: * : Unsupported major.minor version 52.0 解决办法

    Exception in thread "main" java.lang.UnsupportedClassVersionError: * : Unsupported major.m ...

  7. OKEX量化分析报告[2017-12-08]

    [生成时间]2017-12-08 21:07:46 [报告内容]DASH_USDT短期     3.0中期     1.0长期      —— LRC_USDT短期     4.0中期      —— ...

  8. Web性能测试通用标准

    性能指标 通过 不通过 备注 响应时间 <期望时间 >期望时间 1.所有性能指标期望值是根据性能测试申请单取值: 2.响应时间2-5-8原则: 响应时间在2-5秒内,系统的响应速度比较快: ...

  9. Buns---cf 106C(多重背包)

    题目链接:http://codeforces.com/problemset/problem/106/C 题意:有n克面粉,m种馅料,然后每种馅料有ai克,bi克馅料和ci克面粉做的面包可以买di元,也 ...

  10. 通过EditText的setTransformationMethod()隐藏或显示密码

    private Button mBtnPassword; private EditText mEtPassword; private boolean mbDisplayFlg = false; /** ...