提高数据库查询效率的相关优化

           1、查询时只查出需要的字段,避免查询无用的字段 

           2、尽量先投影再连接 即 在最终结果查询出来后,再进行关联子查询 

           3、 避免在where子句中使用in,not in,or 或者having。 

                可以使用 exist 和not exist代替 in和not in。 

                可以使用表链接代替 exist。Having可以用where代替,如果无法代替可以分两步处理。 

                例子: 

                SELECT * FROM ORDERS WHERE CUSTOMER_NAME NOT IN 

                (SELECT CUSTOMER_NAME FROM CUSTOMER) 

                优化: 

                SELECT * FROM ORDERS WHERE CUSTOMER_NAME not exist 

                (SELECT CUSTOMER_NAME FROM CUSTOMER) 

           4、避免使用耗费资源的操作,带有DISTINCT,UNION,MINUS,INTERSECT,ORDER BY的SQL语句会启动SQL引擎 执行,耗费资源的排序(SORT)功能. 

              DISTINCT需要一次排序操作, 而其他的至少需要执行两次排序 

           5、对于有大量数据的表要建立索引,索引可大大提高查询效率。 

              建立索引的方法: 

                   a、一张数据库表可以针对不同的列建立多个索引,如下图,图中是在PL/SQL中对T_FP_IMPORTDATA表创建的索引,索引的名称不可重复。

              也可以用SQL语句创建索引,如创建单列索引: CREATE INDEX I_T_FP_IMPORTDATA_C ON T_FP_IMPORTDATA (ORGANIZATION);

                   创建多列索引:CREATE INDEX I_T_FP_IMPORTDATA_B ON T_FP_IMPORTDATA (FPDM,FPHM);

                   b、可创建索引的列:经常需要搜索的列,经常用在连接的列,经常需要排序的列,经常使用在WHERE子句中的列等。

                   c、不应该创建索引的列:很少使用或者参考的列,只有很少数据值的列(如ID列数据值多,状态列数据值少),修改性能远远大于检索性能的列,定义为text, image和bit数据类型的列等

             d、要注意的是,建立太多的索引将会影响更新和插入的速度,因为它需要同样更新每个索引文件。

        使用索引需注意,以下情况会不走索引,而进行全表扫描:

             a、where子句中没有使用索引的第一列,如:select fpdm,fphm from t_fp_importdata where fphm='06386786' 

             b、有索引的字段使用了函数、表达式、部分隐式转换、like和substr、查询所有null值、否定形式 等。

转载于:https://my.oschina.net/u/2282777/blog/727580

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值