科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航

至顶网软件频道教你快速掌握Informix SQL的11个使用技巧 (1)

教你快速掌握Informix SQL的11个使用技巧 (1)

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

如果你有排序和连接操作,你可以先select数据到一个临时表中,然后再对临时表进行处理。因为临时表是建立在内存中,所以比建立在磁盘上表操作要快的多。

作者:ziyi 来源:赛迪网 2007年9月19日

关键字: SELECT TOP N select SQL Informix

  • 评论
  • 分享微博
  • 分享邮件
 

一、加快sql的执行速度

1.select 语句中使用sort,或join

如果你有排序和连接操作,你可以先select数据到一个临时表中,然后再对临时表进行处理。因为临时表是建立在内存中,所以比建立在磁盘上表操作要快的多。

如:

SELECT time_records.*, case_name  

FROM time_records, OUTER cases  

WHERE time_records.client = "AA1000"  

AND time_records.case_no = cases.case_no  

ORDER BY time_records.case_no

这个语句返回34个经过排序的记录,花费了5分钟42秒。而:

SELECT time_records.*, case_name  

FROM time_records, OUTER cases  

WHERE time_records.client = "AA1000"  

AND time_records.case_no = cases.case_no  

INTO temp foo;  

SELECT * from foo ORDER BY case_no  

返回34条记录,只花费了59秒。

2.使用not in 或者not exists 语句

下面的语句看上去没有任何问题,但是可能执行的非常慢:

SELECT code FROM table1  

WHERE code NOT IN ( SELECT code FROM table2 

如果使用下面的方法: 

SELECT code, 0 flag  

FROM table1  

INTO TEMP tflag;  

然后: 

UPDATE tflag SET flag = 1 

WHERE code IN ( SELECT code  FROM table2  

WHERE tflag.code = table2.code ; 

然后: 

SELECT * FROM  

tflag  

WHERE flag = 0;

看上去也许要花费更长的时间,但是你会发现不是这样。

事实上这种方式效率更快。有可能第一种方法也会很快,那是在对相关的每个字段都建立了索引的情况下,但是那显然不是一个好的注意。

    • 评论
    • 分享微博
    • 分享邮件
    邮件订阅

    如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。

    重磅专题
    往期文章
    最新文章