- 浏览: 245005 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (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 715浅谈hibernate性能优化的几点建议1、针对oracle数 ... -
hibernate 效率问题总结
2012-05-17 16:14 884一、“精心编写”的JDBC ... -
Hibernate 批量删除 问题
2012-05-17 15:24 825批量处理数据 通常, ... -
Hibernate 二级缓存
2012-04-20 10:35 870二级缓存 Hibernate 对数据的缓存包括两个级: ... -
hibernate对象的三种状态及之间的转换 .
2012-04-20 10:36 1082Hibernate的对象有3种状态,分别为:瞬时态(Trans ... -
hibernate之检索策略与检索方式
2012-03-11 10:54 877检索策略包括 立即检索 延迟检索 迫切左外连接 类级别的可以 ... -
spring+hibernate中处理oracle BLOB
2012-02-28 16:11 8421、配置hibernate: 1.1、配置hiber ... -
使用JDBC和Hibernate来写入Blob型数据到Oracle中(1)
2012-02-28 16:09 807转 Oracle的Blob字段比较特殊,他比long字段的性 ... -
HibernateTemplate 源码分析(三)OpenSessionInViewFilter
2012-02-20 11:45 1034OpenSessionInViewFilter作为一个filt ... -
HibernateTemplate 源码分析(二)
2012-02-20 10:44 1061在Spring中使用Hibernate的方法: 因为最终需 ... -
threadlocal threadlocalMap 在hibernate spring中的应用
2012-02-16 16:45 1136之前看资料,总说spring hibernate 是通过thr ... -
理解ThreadLocal
2012-02-16 15:35 700理解ThreadLocal . ThreadLocal是 ... -
Spring+Hibernate 之懒加载问题的解决
2012-02-15 17:30 699http://blog.csdn.net/aspdao/art ... -
关于OpenSessionInView
2012-02-15 16:49 1128关于OpenSessionInView . 简而言之,就是通 ... -
OpenSessionInViewFilter源码分析
2012-02-15 16:32 1125OpenSessionInViewFilter源码 ... -
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 919转 在使用hibernate进行持久化时,有时需要动态的改 ...
相关推荐
通讯录数据库表aaaaaaaaaaa
Hadoop学习笔记AAAAAAAAAAA
2.5作业aaaaaaaaaaa
数据库考试aaaaaaaaaaa
yee~
py代码-aaaaaaaaaaa
往年数学知识点
aaaaaaaaaaa
aaaaaaaaaaa
aaaaaaaaaaa
打印三角形图案 编一程序显示由符号组成的三角形图案。例如,程序运行后, 屏幕显示:How many lines? 用户输入:5 屏幕显示:What character? 用户输入:* 则输出如下图案 * *** ...aaaaaaaaaaa
SQL> insert into test_char values('aaaaaaaaaaa'); insert into test_char values('aaaaaaaaaaa') ORA-12899: value too large for column "PUB_TEST"."TEST_CHAR"."COLA" (actual: 11, maximum: 10) 3. ...
aaaaaaaaaaa是在运行时刻赋值的; 而bbbbbbbbbbb是在编译时就确定的; 但是,在以后的存取中,在栈上的数组比指针所指向的字符串(例如堆)快。 比如: #include void main() { char a = 1; char c[] = ...
aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
DGIM 的C++实现AAAAAAAAAAA
ン ニ ャ ー 支持语言:日本語
在做个东西要滚动代码 而且是无缝的 搞了半天还是不行 决心一定要把这个问题搞定 经过研究 也不难 代码如下: 程序代码 代码如下: style> align=top> valign> <p>aaaaaaaaaaa <p>aaaaaaaaaaa <p>...
SAP講解圖文AAAAAAAAAAA.