相信越来越多的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安全漏洞的产生: