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. Windows Phone 编程: 摇一摇 效果

    Step 1: 下载摇晃手势开发库 http://create.msdn.com/en-us/edu ... ake_Gesture_LibraryStep 2: 解压后进入 ShakeGesture ...

  2. 应用二:Vue之ElementUI Form表单校验

    (注:本文适用于有一定Vue基础或开发经验的读者,文章就知识点的讲解不一定全面,但却是开发过程中很实用的)   表单校验是前端开发过程中最常用到的功能之一,根据个人的工作经验总结在此对表单校验功能的基 ...

  3. JavaScript数组操作函数

    A: 购物车会有这样的情况,购物车是一个数组,每一个商品是一个对象,分别对应一个id,和一个num ,然后改变商品的时候需要和购物车对比,如果购物车中有这个商品的话,就只改变这个商品对应的id的num ...

  4. Jquery数字转盘:

    项目中,在充值流程中,加入了1个抽奖环节,需要转盘显示抽中的虚拟货币.网上找了相关的特效,最后锁定在这个特效上:http://www.jb51.net/jiaoben/319636.html.因为用的 ...

  5. JS 九九运算表

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  6. SQL Server UPDATE语句的用法详解

    SQL Server UPDATE语句用于更新数据,下面就为您详细介绍SQL Server UPDATE语句语法方面的知识,希望可以让您对SQL Server UPDATE语句有更多的了解. 现实应用 ...

  7. IOS - Display a base64 image within a UIImageView: 显示一个base64的图片

    base64字符串(base64String)-存的是image数据NSData* data = [[NSData alloc] initWithBase64EncodedString:base64S ...

  8. [CodeForces]981C Useful Decomposition

    李煜东dalao今天给我们讲课了QwQ ppt上一道题 英文题说一下题意吧,以后又看不懂了 将一棵树分割成多个简单路径,每个边只能在一条路径上,但至少有一个公共节点. 输出简单路径分割方法/No 由题 ...

  9. nginx 301 重定向设置不含www到www域名

    如果需要将不含www主机的域名301重定向到含www的域名,如将 shwww.net 重定向至 www.shwww.net,nginx 配置指令如下: server { server_name shw ...

  10. Oracle查看哪些表被锁住了

    --查看哪些表被锁住了select b.owner,b.object_name,a.session_id,a.locked_mode from v$locked_object a,dba_object ...