优化SQL语句

来源:网络 责任编辑:栏目编辑 发表时间:2013-07-01 07:49 点击:

 

一、优化SQL语句,如下面:

 

1、WHERE子句中的连接顺序.

 

   ORACLE采用自下而上的顺序解析WHERE子句,根据这个原理,表之间的连接必须写在其他WHERE条件之前, 那些可以过滤掉最大数量记录的条件必须写在WHERE子句的末尾.

 

 

 

2、SELECT子句中避免使用SELECT *,需要什么字段就列什么字段

 

 

 

 

 

3、 用EXISTS替代IN,NOT EXISTS替代NOT IN

 

实例一:如“异常数据查询”中,使用了in,每一次都要对表进行全表扫描,非常的慢。可使用EXISTS代替。可看我修改后的代码(由于此处使用EXISTS多出了一些记录,所以我没使用)。我的思路是,先查出所有的表,SQL语句不要IN,经过异常过滤后应该余下最多几十条,这时再查询是否在door_mteter中,不存在移除即可。

 

实例二:同样如“异常数据查询”中,可把要IN的ID全部查询出来,放入StringBuilder,然后在SQL语句中再IN StringBuilder,如下代码

 

                StringBuilder sbTemp = new StringBuilder();

 

                sSql = "select METERID from Meter where ...;

 

                data.RunSQL(ref dttemp, sSql);

 

                for (int i = 0; i < dttemp.Rows.Count; i++)

 

                {

 

                    sbTemp.Append(dttemp.Rows[i]["METERID"] + ",");

 

                }

 

 

 

                dttemp.Dispose();

 

 

 

                sSql = "select ....

 

                if (sbTemp.ToString() != "")

 

                    sSql += " and a.METERNO not in (" + sbTemp.ToString().Trim(',') + ")";

 

发现锦西大部分是这种情况,IN 或者NOT  IN,IN 一次就需要2分钟左右。修改后明显提升,10几秒可以查询

 

 

 

4、用表连接替换EXISTS

 

     通常来说, 采用表连接的方式比EXISTS更有效率

 

      SELECT ENAME

 

      FROM EMP E

 

      WHERE EXISTS (SELECT ‘X’

 

                      FROM DEPT

 

                      WHERE DEPT_NO = E.DEPT_NO

 

                      AND DEPT_CAT = ‘A’);

 

     (更高效)

 

      SELECT ENAME

 

      FROM DEPT D,EMP E

 

    相关新闻>>

      发表评论
      请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
      用户名: 验证码:点击我更换图片
      最新评论 更多>>

      推荐热点

      • Request.ServerVariables 参数大全
      • 执行全文索引时出现权限不足的解决方法
      • 导入excel文件处理流程节点的解决方案
      • 查看sql修改痕迹(SQL Change Tracking on Table)
      • MongoDB安装为Windows服务方法与注意事项
      • App数据层设计及云存储使用指南
      • PostgreSQL启动过程中的那些事三:加载GUC参数
      • 写给MongoDB开发者的50条建议Tip1
      • Percolator与分布式事务思考(二)
      网站首页 - 友情链接 - 网站地图 - TAG标签 - RSS订阅 - 内容搜索
      Copyright © 2008-2015 计算机技术学习交流网. 版权所有

      豫ICP备11007008号-1