文档章节

DB2 char()函数引起全表扫描

J
 JackMo2015
发布于 2015/12/03 12:19
字数 324
阅读 110
收藏 0

解决方法是情愿多几次访问数据库,增加 Where 条件 缩小检索范围,不要用连接

原代码:

List l = new ArrayList();  
StringBuffer sql = new StringBuffer(); 

sql.append("select log.LOGID,log.LASID,customerinfo.REALNAME,customer.IDTYPE,
            char(date(log.OPERATEDATE))||' '||char(time(log.OPERATEDATE)),log.OPERATETYPE,");  
sql.append("log.OPERATECODE,log.PRINTSTATE,log.FIRSTPRINTDATE,log.LASTPRINTDATE,log.LASTPRINTCODE,"); 
sql.append("log.EMAILSTATE,log.FIRSTEMAILDATE,log.LASTEMAILDATE,log.LASTEMAILCODE,log.PRINTID,"); 
sql.append("log.EMAILID,log.FLAG,customer.IDNO,customerinfo.SEX,customer.email,customer.mobile 
            from 日志表 as log, 客户表 as customer, 客户详情表 as customerinfo 
            
where log.LASID = char(customer.CUSTOMERID) 
and char(customer.CUSTOMERID)= char(customerinfo.CUSTOMERID)");

中 Where  条件 用到了 char() 函数,原来 DB2 中 where 条件中 引用函数会引起全表扫描,逻辑没有什么错,就是线程卡在这里。

修改: 分两部分 先将 顾客ID搜出来,再去搜日志

  1.先将 顾客ID搜出来

select customer.CUSTOMERID from 客户表 as customer, 客户详情表 as customerinfo 
where customer.CUSTOMERID= customerinfo.CUSTOMERID for read only with ur

  2.再去搜日志

StringBuffer sql = new StringBuffer(); 

sql.append("select log.LOGID,log.LASID,customerinfo.REALNAME,customer.IDTYPE, 
            char(date(log.OPERATEDATE))||' '||char(time(log.OPERATEDATE)),log.OPERATETYPE,"); 
sql.append("log.OPERATECODE,log.PRINTSTATE,log.FIRSTPRINTDATE,log.LASTPRINTDATE,log.LASTPRINTCODE,"); 
sql.append("log.EMAILSTATE,log.FIRSTEMAILDATE,log.LASTEMAILDATE,log.LASTEMAILCODE,log.PRINTID,");  
sql.append("log.EMAILID,log.FLAG,customer.IDNO,customerinfo.SEX,customer.email,customer.mobile 
            from 日志表 as log, 客户表 as customer,客户详情表 as customerinfo 
            
where log.LASID in ("); 	
for(Object CustomerId : CustomerIds){
    sql.append("'"+CustomerId.toString()+"',"); 
}
sql.deleteCharAt(sql.lastIndexOf(","));
sql.append(") AND for read only with ur");

记得加上 " for read only with ur "


© 著作权归作者所有

共有 人打赏支持
J
粉丝 3
博文 126
码字总数 39719
作品 0
广州
高级程序员
mysql数据库优化(sql语句优化)

整理这篇文档也算是有感而发,起因就是染布生产进度大约5W多条数据,每次导出为excel表格的时候服务器上的cpu压力爆满,而项目的架构又从源头上限制了从硬件层面上优化,故本篇文章仅仅从sql...

机智的明
08/06
0
0
SQL --优化小结

对查询进行优化 0.任何地方都不要使用 select from t_tble,要用具体的字段代替 号,尽量不要返回用不到的字段。 1.尽量避免全表扫描,即如下语句 select * from t_test 理论上不会存在如上业...

求是科技
2016/05/04
71
0
IBM原厂资深专家:DB2优化器和成本模型分析

src="https://mmbiz.qlogo.cn/mmbiz/tibrg3AoIJTtkVh8u4bRkfIvjE5vpWNPjaS8nibudC4PvBdVmjtu5iaIXwzMl0gic2CuBKn5NicfHZuwzFvUSia59YDw/0?wxfmt=jpeg" data-ratio="0.5889328063241107" data......

刘俊
2015/11/19
0
0
数据库SQL优化大总结之 百万级数据库优化方案

1.对查询进行优化,要尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引。 2.应尽量避免在 where 子句中对字段进行 null 值判断,否则将导致引擎放弃使用索引而进行全表...

51GT
2017/08/16
0
0
DB2权限与授权

DB2权限与授权 转载地址:http://blog.itpub.net/22661144/viewspace-1477189/ --权限相关的视图 db2 "select substr(tabname,1,30) as tabname from syscat.tables where tabschema='SYSCAT......

huazhixu123
2017/11/20
0
0

没有更多内容

加载失败,请刷新页面

加载更多

如何通过 J2Cache 实现分布式 session 存储

做 Java Web 开发的人多数都会需要使用到 session (会话),我们使用 session 来保存一些需要在两个不同的请求之间共享数据。一般 Java 的 Web 容器像 Tomcat、Resin、Jetty 等等,它们会在...

红薯
今天
3
0
C++ std::thread

C++11提供了std::thread类来表示一个多线程对象。 1,首先介绍一下std::this_thread命名空间: (1)std::this_thread::get_id():返回当前线程id (2)std::this_thread::yield():用户接口...

yepanl
今天
3
0
Nignx缓存文件与动态文件自动均衡的配置

下面这段nginx的配置脚本的作用是,自动判断是否存在缓存文件,如果有优先输出缓存文件,不经过php,如果没有,则回到php去处理,同时生成缓存文件。 PHP框架是ThinkPHP,最后一个rewrite有关...

swingcoder
今天
1
0
20180920 usermod命令与用户密码管理

命令 usermod usermod 命令的选项和 useradd 差不多。 一个用户可以属于多个组,但是gid只有一个;除了gid,其他的组(groups)叫做扩展组。 usermod -u 1010 username # 更改用户idusermod ...

野雪球
今天
3
0
Java网络编程基础

1. 简单了解网络通信协议TCP/IP网络模型相关名词 应用层(HTTP,FTP,DNS等) 传输层(TCP,UDP) 网络层(IP,ICMP等) 链路层(驱动程序,接口等) 链路层:用于定义物理传输通道,通常是对...

江左煤郎
今天
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部