oracle 两表关联时,年月条件的写法引起的巨大性能的差异

需求是要比较最近两个月的值,进行数据检验!所以我用自关联,来将两个月的数据放到一行上,然后进行比较!

sql语句类似于:

select b.ny,b.dwdm,。。。。,
     a.js  as sy_js , b.js,    --取出上下两个月的同一列的指标。
     。。。。。。。
 from tjxx_10 a,tjxx_10 b where    a.dwdm=b.dwdm and a.shbz=b.shbz and a.csxm=b.csxm
  and b.ny='201508' and a.ny=b.ny-1

这个语句就是把tjxx_10自关联一下,然后让a行指标201507,b行指标201508.

由于该表已经比较大了有几十万行吧!结果上面执行查询,就要4秒左右。

第一次修改:

 and b.ny='201508' and a.ny=201507

这么关联,还是4秒。

第二次修改

and b.ny='201508' and a.ny='201507'

结果竟然是 0.02秒。

结论:一直以来,我认为在sql中,ny列是varchar2(6)

a.ny=b.ny-1 或者a.ny=201507这种写法都是对的。因为都能正确执行。我认为oracle会自动把数字转为字符串!

但今天遇到这个超大表时,展示出的性能差异说明oracle对上面两种情况都不能利用索引,

因为右侧相当于一个函数,可能要遍历每一行记录,

切记:ny='201507'  不要再写做  ny=201507    了。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏技术专栏

Spark SQL/Hive调优

任务进度长时间维持在99%(或100%),查看任务监控页面,发现只有少量(1个或几个)reduce子任务未完成。因为其处理的数据量和其他reduce差异过大。 ...

85020
来自专栏叔叔的博客

遇到的java随机数引起的阻塞问题

最后通过使用jstack -[pid],发现 sun.security.provider.SecureRandom 这里锁住了,原来这是java产生随机数造成了...

11040
来自专栏瓜大三哥

桶式移位器

桶式移位器是一种组合逻辑电路,通常作为微处理器CPU的一部分。它具有n个数据输入和n个数据输出,以及指定如何移动数据的控制输入,指定移位方向、移位类(循环、算术...

28970
来自专栏吉浦迅科技

在cuda的核函数中可以按地址调用普通变量么?

请问在cuda的核函数中可以按地址调用普通变量么? GPU世界论坛 bbs.gpuworld.cn Hi, 楼主, 完全无问题,从Fermi起引入卡内统...

40570
来自专栏算法+

不用第三方解码库取得图片宽高 附完整C++算法实现代码

在特定的应用场景下,有时候我们只是想获取图片的宽高, 但不想通过解码图片才取得这个信息。 预先知道图片的宽高信息,进而提速图片加载,预处理等相关操作以提升体验。...

45460
来自专栏java一日一条

Github 的清点对象算法

这就叫”清点对象”(counting objects),Github需要实时计算出来,需要克隆的对象总数。

8920
来自专栏HansBug's Lab

关于使用lazytag的线段树两种查询方式的比较研究

说到线段树,想来大家并不陌生——最基本的思路就是将其规划成块,然后只要每次修改时维护一下即可。 但是尤其是涉及到区间修改时,lazytag的使用往往能够对于程序...

33670
来自专栏沈唁志

文本处理,第2部分:OH,倒排索引

这是我的文本处理系列的第二部分。在这篇博客中,我们将研究如何将文本文档存储在可以通过查询轻松检索的表单中。我将使用流行的开源Apache Lucene索引进行说...

19540
来自专栏深度学习那些事儿

提升python项目完成效率的调试方法技巧(上)

效率提升是极为重要的事情,我们的时间本来就不充裕,不应该过多将时间浪费在调试过程中。对于大型项目光有dubug是不够的,如果需要提高产品调试进度,必须需要采取一...

44170
来自专栏YG小书屋

MapReduce:N keys,N files(三)数据倾斜优化

还是如何将N个keys写到N个文件的需求。 这次的问题是单个key太大,引起的单个reduce任务执行时间过长,导致整个MR运行时间过长。数据大部分的key在...

10520

扫码关注云+社区

领取腾讯云代金券