oracle行级子查询优化,子查询很多,如何优化

子查询很多,怎么优化?

如题,

中间件XML文件的SQL如下:查20行左右的数据要4秒左右,怎么优化一下?谢谢

select * from (

select pt_user_id,

pt_user_name,

contract_id,

min(anr) anr,

pay_style,

period_num,

(select qh_res_id from bs.etb_v_order_card_term b where b.sale_contract_id = a.contract_id and b.pt_user_id = a.pt_user_id and rownum<=1) qh_res_id,

(select delivery_flag from bs.etb_v_order_card_term b where b.sale_contract_id = a.contract_id and b.pt_user_id = a.pt_user_id and rownum<=1) cer_self_take,

b_typename,

total_qty,

make_date,

valid_date,

(select contract_intent_status from bs.etb_v_order_card_term b where b.sale_contract_id = a.contract_id and b.pt_user_id = a.pt_user_id and rownum<=1) ht_status,

(select delivery_e_name from pnf_contract_delivery c where c.type_id = '1' and c.contract_id is not null and c.customer_id=a.customer_id and c.contract_id = a.contract_id and rownum<=1) qr_man,

a.contract_status co_status,

customer_id,

cust_name,

b_typeid,

(select sales_contract_id from bs.etb_v_order_card_term b where b.sale_contract_id = a.contract_id and b.pt_user_id = a.pt_user_id and rownum<=1)  sales_contract_id,

(select sh_name from bs.etb_v_order_card_term b where b.sale_contract_id = a.contract_id and b.pt_user_id = a.pt_user_id and rownum<=1)  sh_name,

(select end_trans_dw from bs.etb_v_order_card_term b where b.sale_contract_id = a.contract_id and b.pt_user_id = a.pt_user_id and rownum<=1)  end_trans_dw,

(select end_trans_dw_name from bs.etb_v_order_card_term b where b.sale_contract_id = a.contract_id and b.pt_user_id = a.pt_user_id and rownum<=1)  end_trans_dw_name,

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值