oracle11g 一条几百行行的sql语句 优化 需要适可而止才行

面对同事报告的一条运行缓慢、长达几百行的SQL语句,通过F5分析发现bis_must2和bis_mf_adjust表存在表扫描问题。为bis_must2表添加索引后,查询成本降低,执行效率显著提升至0.1秒。优化应适可而止,避免过度索引影响DML性能。
摘要由CSDN通过智能技术生成

1,同事报告了一条非常复杂的sql,说很慢,叫我优化下。

很慢的sql,也很长有几百行吧,^_^,如下:

select bm2.bis_must_id,

       bm2.qz_year_month,

       bm2.money,

       bm2.adjust_money,

       bm2.bis_cont_id,

       bm2.must_type,

       bm2.rent_last_pay_date,

       bc.BIS_STORE_IDS,

       bc.BIS_STORE_NOS,

       bc.BIS_SHOP_ID,

       bc.BIS_SHOP_NAME,

       bc.BIS_PROJECT_ID,

       bp.short_name,

       bp.project_name,

       bm2.billing_period_begin,

       bm2.billing_period_end

  from (selectsum(m.money) money,

               sum(aj.adjust_money) adjust_money,

               m.must_type must_type,

               m.qz_year_month qz_year_month,

               m.bis_project_id bis_project_id,

               m.bis_cont_id bis_cont_id,

               max(m.rent_last_pay_date) rent_last_pay_date,

               max(m.billing_period_begin) billing_period_begin,

               min(m.billing_period_end) billing_period_end,

               max(m.bis_must_id) bis_must_id

          from bis_must2 m,

               (select j.*

                  from bis_mf_adjust j

                 where (j.is_del = '1'or j.is_del isnull)

                   and j.adjust_type = 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值