`

AAAAAAAAAAA

 
阅读更多
相信越来越多的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的话,那么如果参数值为中文会有问题,用参数可以解决这个问题
分享到:
评论

相关推荐

    1.算法部分aaaaaaaaaaa

    算法部分aaaaaaaaaaa"暗示我们将深入探讨C++中的算法设计与实现。 在C++中,算法的实现通常涉及到数据结构,如数组、链表、栈、队列、树和图等。这些数据结构为高效算法提供了基础。例如,排序算法(如冒泡排序、...

    aaaaaaaaaaa'用户权限管理系统

    本系统以"aaaaaaaaaaa'用户权限管理系统"为标题,暗示其专注于管理和控制用户对系统资源的访问权限。结合标签"java",我们可以推断这个系统是使用Java编程语言开发的,Java因其跨平台兼容性和强大的安全性而常被用于...

    通讯录数据库表aaaaaaaaaaa

    通讯录数据库表aaaaaaaaaaa

    12-3微分方程.aaaaaaaaaaa

    12-3微分方程.aaaaaaaaaaa

    2017—2018学年度第二学期一年级数学1、2、3单元aaaaaaaaaaa数学知识点.doc

    从【标题】"2017—2018学年度第二学期一年级数学1、2、3单元aaaaaaaaaaa数学知识点.doc"中不难看出,这份文档汇集了对于一年级学生至关重要的数学知识点,目的是为孩子们打下坚实的基础,培养他们解决实际问题的能力...

    aaaaaaaaaaa截图

    aaaaaaaaaaa截图

    Aaaaaaaaa!aaaaaaaaaaa

    Aaaaaaaaa!aaaaaaaaaaa

    red hat aaaaaaaaaaa

    red hat aaaaaaaaaaa

    Hadoop学习笔记AAAAAAAAAAA

    《深入理解Hadoop分布式系统》 Hadoop是一个开源的分布式计算框架,主要由Apache基金会维护,广泛应用于大数据处理领域。其核心组件包括HDFS(Hadoop Distributed File System)和MapReduce,以及后来引入的YARN...

    py代码-aaaaaaaaaaa

    在给定的“py代码-aaaaaaaaaaa”项目中,我们可以看到两个主要的文件:main.py 和 README.txt。这些文件对于理解和使用Python代码至关重要。本文将详细介绍这两个文件在Python开发中的作用以及相关的编程知识点。 ...

    aaaaaaaaaaa

    aaaaaaaaaaa

    2.5作业aaaaaaaaaaa

    根据提供的文件内容,我们可以从中提炼出一系列与C语言相关的知识点。这些知识点主要集中在基础语法、逻辑判断、位运算以及字符串处理等方面。下面是针对题目中提到的知识点进行详细解析: ### 1....

    数据库考试aaaaaaaaaaa

    数据库考试相关知识点总结 本资源摘要信息涵盖了数据库考试的多个方面,包括数据库设计、数据准备、数据库查询、视图、存储过程、触发器等。通过对数据库考试的深入分析,我们可以总结出以下几个重要的知识点: ...

    DGIM.zip_DGIM

    【描述】"DGIM 的C++实现AAAAAAAAAAA" 提到的"AAAAAAAAAAA"可能是由于某种原因被填充的占位符,或者表示在实现过程中遇到了一些具体的问题,如调试、优化或复杂度控制。C++实现DGIM需要理解以下几个关键概念: 1. *...

    网吧QQ号码鉴听

    描述中的"aaaaaaaaaaa"可能是由于保密原因或意外留空,没有提供具体的技术细节。但我们可以根据这个主题推测,鉴听行为可能涉及到网络嗅探技术,如使用Wireshark等工具捕获网络数据包,然后分析这些数据包以找出QQ...

    房屋技术报告(市场法及收益法)作业.pdf

    本报告以“房屋技术报告(市场法及收益法)”为主题,结合具体的估价项目——AAAAAAAAAAA房地产抵押价格评估,深入探讨了估价方法与流程。 估价项目位于重庆市BBBB区钓办处嘉滨路289号,涵盖了商业门面和车库(库房)...

    WPE.rar_wpe

    描述中的“可以使用的wpe恩蛮好用哪个aaaaaaaaaaa”虽然语句不是很清晰,但可以理解为用户认为这个WPE版本是好用的,可能在某种场景下表现出了较好的功能或易用性。 标签"WPE"进一步确认了我们讨论的主题,即WPE...

    Oracle存储过程-1

    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存储过程-1.docx

    当尝试插入超过最大长度的字符串时,Oracle会抛出错误,如尝试插入'aaaaaaaaaaa'时出现的ORA-12899错误。 2. VARCHAR2是变长的字符类型,与CHAR不同,它只存储实际输入的字符长度,不填充空格。这更节省存储空间,...

Global site tag (gtag.js) - Google Analytics