mybaitis书写sql需要特别注意where条件中的语句,否则将会导致索引失效,使得查询总是超时。如下语句会出现导致索引失效的情况:

with test1 as (select count(C_FUNDACCO) val,'a' v from TINF_REQUEST a
where a.C_FUNDCODE = #{cFundcode} and a.D_DATADATE = #{dDatadate}),
test2 as (select count(C_FUNDACCO) val,'a' v from TINF_CONFIRM b
where b.C_FUNDCODE = #{cFundcode} and b.D_DATADATE = #{dDatadate}),
test3 as (select count(C_FUNDACCO) val,'a' v from TINF_DIVIDENDDETAIL c
where c.C_FUNDCODE = #{cFundcode} and c.D_DATADATE = #{dDatadate}),
test4 as (select count(C_FUNDACCO) val,'a' v from TINF_SHAREDETAIL f
where f.C_FUNDCODE = #{cFundcode} and f.D_DATADATE = #{dDatadate})
select test1.val requestCount,test2.val confirmCount,test3.val dividendCount,test4.val shareDeatilCount from test1,test2,test3,test4 where test1.v=test2.v and test2.v=test3.v and test3.v=test4.v

原因:直接使用#{dDatadate}导致索引的失效。

sql语句中出现几种情况会导致索引失效:

1.TO_CHAR(a.D_DATADATE, 'yyyy-mm-dd') <= TO_CHAR(#{dDatadateStart}, 'yyyy-mm-dd'),导致索引失效。

2.trunc(created)>=TO_DATE('2013-12-14', 'YYYY-MM-DD'),导致索引失效。

3.c.D_DATADATE = #{dDatadate},导致索引失效。

将上述语句加上TO_DATE函数,改为如下语句,不会导致索引失效:

with test1 as (select count(C_FUNDACCO) val,'a' v from TINF_REQUEST a
where a.C_FUNDCODE = #{cFundcode} and a.D_DATADATE = TO_DATE(#{dDatadate},'yyyy-MM-dd')),
test2 as (select count(C_FUNDACCO) val,'a' v from TINF_CONFIRM b
where b.C_FUNDCODE = #{cFundcode} and b.D_DATADATE = TO_DATE(#{dDatadate},'yyyy-MM-dd')),
test3 as (select count(C_FUNDACCO) val,'a' v from TINF_DIVIDENDDETAIL c
where c.C_FUNDCODE = #{cFundcode} and c.D_DATADATE = TO_DATE(#{dDatadate},'yyyy-MM-dd')),
test4 as (select count(C_FUNDACCO) val,'a' v from TINF_SHAREDETAIL f
where f.C_FUNDCODE = #{cFundcode} and f.D_DATADATE = TO_DATE(#{dDatadate},'yyyy-MM-dd'))
select test1.val requestCount,test2.val confirmCount,test3.val dividendCount,test4.val shareDeatilCount from test1,test2,test3,test4 where test1.v=test2.v and test2.v=test3.v and test3.v=test4.v

百万、千万级别的数据,加上索引并且使索引生效的sql语句,查询性能会很快。如果sql使得索引失效,将会总是超时,无法加载出来数据。

因此书写sql一定要注意自己写的sql是否使得索引生效,查看执行计划

FULL全表扫描即未使用索引(或索引失效);INDEX使用索引查询,会使得查询效率非常高。

总结:百万、千万级别的数据,在查询sql上使用索引查询,会很大的提高性能。

原来表中不加索引的查询需要5分钟甚至更长时间导致查询超时;加上索引后并且sql使用索引生效,会使得查询几秒就能查询出来数据。

   所以利用好索引,即使面对百万、千万、上亿条数据也不用担心查询超时。

mybatis的sql语句导致索引失效,使得查询超时的更多相关文章

  1. 《MySQL慢查询优化》之SQL语句及索引优化

    1.慢查询优化方式 服务器硬件升级优化 Mysql服务器软件优化 数据库表结构优化 SQL语句及索引优化 本文重点关注于SQL语句及索引优化,关于其他优化方式以及索引原理等,请关注本人<MySQ ...

  2. SQL SERVER 中is null 和 is not null 将会导致索引失效吗?

    其实本来这个问题没有什么好说的,今天优化的时候遇到一个SQL语句,因为比较有意思,所以我截取.简化了SQL语句,演示给大家看,如下所示 declare @bamboo_Code varchar(3); ...

  3. SQL优化避免索引失效

    Oracle 索引的目标是避免全表扫描,提高查询效率,但有些时候却适得其反.例如一张表中有上百万条数据,对某个字段加了索引,但是查询时性能并没有什么提高,这可 能是 oracle 索引失效造成的.or ...

  4. mybatis实战教程(mybatis in action)之八:mybatis 动态sql语句

    mybatis 的动态sql语句是基于OGNL表达式的.可以方便的在 sql 语句中实现某些逻辑. 总体说来mybatis 动态SQL 语句主要有以下几类:1. if 语句 (简单的条件判断)2. c ...

  5. Mybatis 动态Sql语句《常用》

    MyBatis 的强大特性之一便是它的动态 SQL.如果你有使用 JDBC 或其他类似框架的经验,你就能体会到根据不同条件拼接 SQL 语句有多么痛苦.拼接的时候要确保不能忘了必要的空格,还要注意省掉 ...

  6. mybatis 动态sql语句(3)

    mybatis 的动态sql语句是基于OGNL表达式的.可以方便的在 sql 语句中实现某些逻辑. 总体说来mybatis 动态SQL 语句主要有以下几类: 1. if 语句 (简单的条件判断) 2. ...

  7. mybatis 动态sql语句(1)

    mybatis 的动态sql语句是基于OGNL表达式的.可以方便的在 sql 语句中实现某些逻辑. 总体说来mybatis 动态SQL 语句主要有以下几类: 1. if 语句 (简单的条件判断) 2. ...

  8. Java-MyBatis:MyBatis 3 | SQL 语句构建器类

    ylbtech-Java-MyBatis:MyBatis 3 | SQL 语句构建器类 1.返回顶部 1. SQL语句构建器类 问题 Java程序员面对的最痛苦的事情之一就是在Java代码中嵌入SQL ...

  9. 通过Log4j的DEBUG级别来显示mybatis的sql语句

        为了更加方便调试sql语句,需要显示mybatis的sql语句.     网络上的一般方式都是通过log4j来实现,但是很多都有问题.      经过实验,以下代码能够保持正常:(只显示myb ...

随机推荐

  1. 使用Axis2方式发布webService实例说明

    1.简单的pojo方式: 不需要写配置文件,直接把class文件拷贝到axis2的WEB-INF目录下的poji文件夹下即可.但其局限性表现在,实现类不能有包声明,这在实际开发过程中使用较少,这里不做 ...

  2. offset() 方法 文档偏移量

    以前看视频学习听到这个offset()感觉很陌生,没有用过,马上记到笔记里了,今天翻起笔记再次看到,都已经忘记是怎么用的了,所以来到这里狠狠的记下来: offset() 方法返回得或设置元素相对于文档 ...

  3. 解决strip: Unable to recognise the format of the input file问题

    前言   在编译xilinx的uboot的时候出现了一个问题,始终报错:“strip: Unable to recognise the format of the input file `gen_et ...

  4. layer弹出框的用法

    页面中引入  layer.js 就行了 1.弹出一个提示信息: layer.msg("我是哦提示信息"); 2.弹出一个带选择的按钮的框 layer.open({ title: ' ...

  5. mysql进阶练习

    一 .  MySQL进阶练习 /*==========================创建班级表=============================*/ CREATE TABLE class ( ...

  6. UVALive-8138 Number Generator 概率dp+优化

    题目链接:https://cn.vjudge.net/problem/UVALive-8138 题意 有一个随机数生成器,输出1-n的整数. 现在已经输出了k个数,问再取几个数才能使取出的所有数的个数 ...

  7. 基于Tags的简单内容推荐的实现

    原来为了简单方便,自己小网站上的文章页的相关内容推荐就是从数据库里随机抽取数据来填充一个列表,所以一点相关性都没有,更本没有办法引导用户去访问推荐内容. 算法选择 如何能做到相似内容的推荐呢,碍于小网 ...

  8. win7下UDL文件不同

    win7 执行UDL文件看不全all驱动.所以没有办法配置数据库的连接.查度娘,方法如下: 在C:\建一个test.udl 文件,运行命令 C:\Windows\syswow64\rundll32.e ...

  9. RobotFrameWork+APPIUM实现对安卓APK的自动化测试----第二篇【原理】

    http://blog.csdn.net/deadgrape/article/details/50574459 接着上一篇,我们开始聊聊APPIUM的框架和运行模式.废话不多说直接上图. 1.首先自动 ...

  10. 可序列化serializable的作用是什么

    什么情况下需要序列化:a)当你想把的内存中的对象写入到硬盘的时候:b)当你想用套接字在网络上传送对象的时候: 为什么要序列化: 为了将对象可以以流的方式传输到其他位置,就必须要将该对象定义为可序列化的 ...