- 浏览: 255349 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (232)
- 瞎扯两句 (8)
- 操作系统 (5)
- 工作笔记 (33)
- 设计模式 (1)
- java (57)
- Java IDE (7)
- hibernate (17)
- oracle (46)
- ms sql (2)
- spring (9)
- struts2 (0)
- javascript (16)
- java_code (2)
- java之集合 (2)
- java之线程 (4)
- java之IO (4)
- java之虚拟机 (6)
- java之异常 (0)
- EJB (4)
- XML (4)
- 数据结构-算法 (2)
- 架构设计 (5)
- 配置信息 (2)
- 阅读笔记 (6)
- IT专业英语 (1)
- PI (0)
- 单元测试 (1)
最新评论
相信越来越多的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销率时,在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性能优化的几点建议
2012-05-17 16:41 755浅谈hibernate性能优化的几点建议1、针对oracle数 ... -
hibernate 效率问题总结
2012-05-17 16:14 925一、“精心编写”的JDBC ... -
Hibernate 批量删除 问题
2012-05-17 15:24 862批量处理数据 通常, ... -
Hibernate 二级缓存
2012-04-20 10:35 904二级缓存 Hibernate 对数据的缓存包括两个级: ... -
hibernate对象的三种状态及之间的转换 .
2012-04-20 10:36 1116Hibernate的对象有3种状态,分别为:瞬时态(Trans ... -
hibernate之检索策略与检索方式
2012-03-11 10:54 909检索策略包括 立即检索 延迟检索 迫切左外连接 类级别的可以 ... -
spring+hibernate中处理oracle BLOB
2012-02-28 16:11 8741、配置hibernate: 1.1、配置hiber ... -
使用JDBC和Hibernate来写入Blob型数据到Oracle中(1)
2012-02-28 16:09 836转 Oracle的Blob字段比较特殊,他比long字段的性 ... -
HibernateTemplate 源码分析(三)OpenSessionInViewFilter
2012-02-20 11:45 1070OpenSessionInViewFilter作为一个filt ... -
HibernateTemplate 源码分析(二)
2012-02-20 10:44 1101在Spring中使用Hibernate的方法: 因为最终需 ... -
threadlocal threadlocalMap 在hibernate spring中的应用
2012-02-16 16:45 1177之前看资料,总说spring hibernate 是通过thr ... -
理解ThreadLocal
2012-02-16 15:35 730理解ThreadLocal . ThreadLocal是 ... -
Spring+Hibernate 之懒加载问题的解决
2012-02-15 17:30 734http://blog.csdn.net/aspdao/art ... -
关于OpenSessionInView
2012-02-15 16:49 1156关于OpenSessionInView . 简而言之,就是通 ... -
OpenSessionInViewFilter源码分析
2012-02-15 16:32 1169OpenSessionInViewFilter源码 ... -
HibernateTemplate 源码分析 之模板模式(一)
2012-02-15 16:04 146HibernateTemplate 从名成上看,其采用了设计模 ... -
HibernateTemplate 源码分析(一)
2012-02-15 16:02 1HibernateTemplate 从名成上看,其采用了设计模 ... -
关于配置文件中的property属性与set,get方法
2012-02-14 23:34 178一直以为在配置文件中有一个property,对应的class里 ... -
Hibernate.initialize(Obj)用法
2011-07-22 14:57 965转 在使用hibernate进行持久化时,有时需要动态的改 ...
相关推荐
算法部分aaaaaaaaaaa"暗示我们将深入探讨C++中的算法设计与实现。 在C++中,算法的实现通常涉及到数据结构,如数组、链表、栈、队列、树和图等。这些数据结构为高效算法提供了基础。例如,排序算法(如冒泡排序、...
本系统以"aaaaaaaaaaa'用户权限管理系统"为标题,暗示其专注于管理和控制用户对系统资源的访问权限。结合标签"java",我们可以推断这个系统是使用Java编程语言开发的,Java因其跨平台兼容性和强大的安全性而常被用于...
通讯录数据库表aaaaaaaaaaa
12-3微分方程.aaaaaaaaaaa
从【标题】"2017—2018学年度第二学期一年级数学1、2、3单元aaaaaaaaaaa数学知识点.doc"中不难看出,这份文档汇集了对于一年级学生至关重要的数学知识点,目的是为孩子们打下坚实的基础,培养他们解决实际问题的能力...
aaaaaaaaaaa截图
Aaaaaaaaa!aaaaaaaaaaa
red hat aaaaaaaaaaa
《深入理解Hadoop分布式系统》 Hadoop是一个开源的分布式计算框架,主要由Apache基金会维护,广泛应用于大数据处理领域。其核心组件包括HDFS(Hadoop Distributed File System)和MapReduce,以及后来引入的YARN...
在给定的“py代码-aaaaaaaaaaa”项目中,我们可以看到两个主要的文件:main.py 和 README.txt。这些文件对于理解和使用Python代码至关重要。本文将详细介绍这两个文件在Python开发中的作用以及相关的编程知识点。 ...
aaaaaaaaaaa
根据提供的文件内容,我们可以从中提炼出一系列与C语言相关的知识点。这些知识点主要集中在基础语法、逻辑判断、位运算以及字符串处理等方面。下面是针对题目中提到的知识点进行详细解析: ### 1....
数据库考试相关知识点总结 本资源摘要信息涵盖了数据库考试的多个方面,包括数据库设计、数据准备、数据库查询、视图、存储过程、触发器等。通过对数据库考试的深入分析,我们可以总结出以下几个重要的知识点: ...
【描述】"DGIM 的C++实现AAAAAAAAAAA" 提到的"AAAAAAAAAAA"可能是由于某种原因被填充的占位符,或者表示在实现过程中遇到了一些具体的问题,如调试、优化或复杂度控制。C++实现DGIM需要理解以下几个关键概念: 1. *...
描述中的"aaaaaaaaaaa"可能是由于保密原因或意外留空,没有提供具体的技术细节。但我们可以根据这个主题推测,鉴听行为可能涉及到网络嗅探技术,如使用Wireshark等工具捕获网络数据包,然后分析这些数据包以找出QQ...
本报告以“房屋技术报告(市场法及收益法)”为主题,结合具体的估价项目——AAAAAAAAAAA房地产抵押价格评估,深入探讨了估价方法与流程。 估价项目位于重庆市BBBB区钓办处嘉滨路289号,涵盖了商业门面和车库(库房)...
描述中的“可以使用的wpe恩蛮好用哪个aaaaaaaaaaa”虽然语句不是很清晰,但可以理解为用户认为这个WPE版本是好用的,可能在某种场景下表现出了较好的功能或易用性。 标签"WPE"进一步确认了我们讨论的主题,即WPE...
INSERT INTO test_char VALUES ('aaaaaaaaaaa'); ``` 这条命令会触发错误`ORA-12899: value too large for column "PUB_TEST"."TEST_CHAR"."COLA"` (actual: 11, maximum: 10),因为超过了`CHAR(10)`的长度限制。...
当尝试插入超过最大长度的字符串时,Oracle会抛出错误,如尝试插入'aaaaaaaaaaa'时出现的ORA-12899错误。 2. VARCHAR2是变长的字符类型,与CHAR不同,它只存储实际输入的字符长度,不填充空格。这更节省存储空间,...