生產環境sql語句調優實戰第三篇
sql語句是比較簡單的,透過查詢SUBSCRIBER_FA_V是一個檢視。在檢視中關聯了幾個和業務核心表。
SELECT TO_CHAR(SUBSCRIBER_NO) SUBSCRIBER_ID,
SUB_STATUS,
SUB_STS_RSN_CD,
TO_CHAR(SUB_STATUS_DATE, 'yyyyMMdd') SUB_STATUS_DATE,
SUBSCRIBER_TYPE
FROM SUBSCRIBER_FA_V
WHERE BAN = :1
AND ROWNUM <= :2
AND SUB_STATUS NOT IN ('C', 'L', 'T')
ORDER BY INIT_ACT_DATE, SUBSCRIBER_NO
如果想做sql檢查,對於sql中傳入的變數,sql monitor提供了很方便的功能。
Binds
Name | Position | Type | Value |
---|---|---|---|
:B2 | 1 | NUMBER | 10308170 |
:B1 | 2 | NUMBER |
6 |
還是來看看執行計劃。
SQL Plan Monitoring Details (Plan Hash Value=1125972187)
Id | Operation | Name |
Estimated Rows |
Cost |
Active Period (11s) |
Execs | Rows |
Memory (Max) |
Temp (Max) |
IO Requests | CPU Activity | Wait Activity | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
. |
0 | SELECT STATEMENT |
. |
. |
. |
|
1 | 1 |
. |
. |
|
. |
. |
||||||||||
. |
1 | . SORT ORDER BY |
. |
6 | 67758 |
|
1 | 1 | 2.0KB |
. |
|
. |
. |
||||||||||
. |
2 | .. COUNT STOPKEY |
. |
. |
. |
|
1 | 1 |
. |
. |
|
. |
. |
||||||||||
. |
3 | ... VIEW | SUBSCRIBER_FA_V | 577K | 59898 |
|
1 | 1 |
. |
. |
|
. |
. |
||||||||||
. |
4 | .... SORT UNIQUE STOPKEY |
. |
577K | 59898 |
|
1 | 1 | 2.0KB |
. |
|
. |
. |
||||||||||
. |
5 | ..... UNION-ALL |
. |
. |
. |
|
1 | 1 |
. |
. |
|
. |
. |
||||||||||
. |
6 | ......NESTED LOOPS |
. |
. |
. |
|
1 | 1 |
. |
. |
|
. |
. |
||||||||||
. |
7 | .......NESTED LOOPS |
. |
1 | 3 |
|
1 | 1 |
. |
. |
|
. |
. |
||||||||||
. |
8 | ........NESTED LOOPS |
. |
1 | 2 |
|
1 | 1 |
. |
. |
|
. |
. |
||||||||||
. |
9 | .........INDEX RANGE SCAN | CHANNEL_1IX | 1 | 1 |
|
1 | 1 |
. |
. |
|
. |
. |
||||||||||
. |
10 | .........TABLE ACCESS BY INDEX ROWID | DISTRIBUTE | 1 | 1 |
|
1 | 1 |
. |
. |
|
. |
. |
||||||||||
. |
11 | ..........INDEX RANGE SCAN | DISTRIBUTE_3IX | 1 | 1 |
|
1 | 1 |
. |
. |
|
. |
. |
||||||||||
. |
12 | ........INDEX UNIQUE SCAN | SUBSCRIBER_PK | 1 | 1 |
|
1 | 1 |
. |
. |
|
. |
. |
||||||||||
. |
13 | ....... TABLE ACCESS BY INDEX ROWID | SUBSCRIBER | 1 | 1 |
|
1 | 1 |
. |
. |
|
. |
. |
||||||||||
. |
14 | ...... VIEW |
. |
577K | 35591 |
|
1 | 0 |
. |
. |
|
|
|
||||||||||
. |
15 | .......WINDOW SORT PUSHED RANK |
. |
577K | 35591 |
|
1 | 522K | 21.2MB | 63.0MB |
|
|
|
||||||||||
. |
16 | ........ HASH JOIN |
. |
577K | 23809 |
|
1 | 550K | 23.4MB | 88.0MB |
|
|
|
||||||||||
. |
17 | .........INDEX FULL SCAN | CHANNEL_1IX | 1M | 1269 |
|
1 | 1M |
. |
. |
|
. |
. |
||||||||||
. |
18 | .........HASH JOIN |
. |
577K | 18648 |
|
1 | 550K | 30.7MB | 40.0MB |
|
|
|
||||||||||
. |
19 | ..........TABLE ACCESS FULL | SUBSCRIBER | 430K | 8704 |
|
1 | 424K |
. |
. |
|
|
|
||||||||||
. |
20 | ..........TABLE ACCESS FULL | DISTRIBUTE | 2M | 6046 |
|
1 | 2M |
. |
. |
|
. |
. |
效能瓶頸都在幾個全表掃描和一個分析函式相關的rank操作中。畢竟返回的記錄數只有1條。如果過多的資源都消耗在一些不正確的連線訪問中,是完全可以避免的。
檢視的內容如下:
SELECT xxxxxxx
1 RANK
FROM subscriber, distribute ed, channel cpc
WHERE cpc.pym_channel_no = ed.target_pcn
AND ed.agreement_no = subscriber.subscriber_no
AND eg_dist_type = 'D'
AND ed.expiration_date IS NULL
AND SUBSCRIBER.SUB_STATUS NOT IN ('C', 'L', 'T')
UNION
SELECT xxxxxxx
FROM (SELECT cpc.ban,
subscriber.prim_resource_val,
subscriber.init_act_date,
SUBSCRIBER.CUSTOMER_ID,
subscriber.subscriber_no,
SUBSCRIBER.SUBSCRIBER_TYPE,
SUBSCRIBER.SUB_STATUS,
SUBSCRIBER.SUB_STS_RSN_CD,
SUBSCRIBER.SUB_STATUS_DATE,
SUBSCRIBER.EFFECTIVE_DATE,
ROW_NUMBER ()
OVER (
PARTITION BY subscriber.subscriber_no
ORDER BY
ed.expiration_date, subscriber.subscriber_no DESC)
AS RANK
FROM subscriber, distribute ed, channel cpc
WHERE cpc.pym_channel_no = ed.target_pcn
AND ed.agreement_no = subscriber.subscriber_no
AND eg_dist_type = 'D'
AND SUBSCRIBER.SUB_STATUS IN ('C', 'L', 'T'))
WHERE RANK = 1
根據執行計劃,出問題的正式標黃的union子句。
根據傳入的引數,是可以走索引的,但是在Union子句中,嵌入了子查詢,導致在整個檢視在資料的訪問中,先全表掃描整個子查詢,然後再匹配傳入的引數。
檢視的內容是不能隨便改的,可能在這種場景中合適,其他的相關查詢就有問題了。
所以嘗試把檢視的內容直接轉換成直接的sql,標黃的部分是做的相應改動。
select xxxxxxx
from (SELECT xxxxxxx
1 RANK
FROM subscriber, event_distribute ed, csm_pay_channel cpc
WHERE cpc.pym_channel_no = ed.target_pcn
AND ed.agreement_no = subscriber.subscriber_no
AND eg_dist_type = 'D'
AND ed.expiration_date IS NULL
AND SUBSCRIBER.SUB_STATUS NOT IN ('C', 'L', 'T')
and cpc.ban = 10308170
UNION
SELECT "SUBSCRIBER_NO",
"INIT_ACT_DATE",
"SUB_STATUS",
"SUB_STS_RSN_CD",
"SUB_STATUS_DATE",
"SUBSCRIBER_TYPE",
"RANK"
FROM (SELECT subscriber.subscriber_no,
SUBSCRIBER.INIT_ACT_DATE,
SUBSCRIBER.SUBSCRIBER_TYPE,
SUBSCRIBER.SUB_STATUS,
SUBSCRIBER.SUB_STS_RSN_CD,
SUBSCRIBER.SUB_STATUS_DATE,
ROW_NUMBER() OVER(PARTITION BY subscriber.subscriber_no ORDER BY ed.expiration_date, subscriber.subscriber_no DESC) AS RANK
FROM subscriber, event_distribute ed, csm_pay_channel cpc
WHERE cpc.pym_channel_no = ed.target_pcn
AND ed.agreement_no = subscriber.subscriber_no
AND eg_dist_type = 'D'
AND SUBSCRIBER.SUB_STATUS IN ('C', 'L', 'T')
and cpc.ban = 10308170)
WHERE RANK = 1)
where SUB_STATUS NOT IN ('C','L','T') and rownum < 6
ORDER BY INIT_ACT_DATE, SUBSCRIBER_ID
看似語句挺長的,但是走了索引執行效率還是很高的。
Elapsed: 00:00:00.01
Statistics
----------------------------------------------------------
0 recursive calls
0 db block gets
22 consistent gets
0 physical reads
0 redo size
857 bytes sent via SQL*Net to client
520 bytes received via SQL*Net from client
2 SQL*Net roundtrips to/from client
3 sorts (memory)
0 sorts (disk)
1 rows processed
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/8494287/viewspace-1347091/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 生產環境sql語句調優實戰第二篇SQL
- 生產環境sql語句調優實戰第四篇SQL
- 生產環境sql語句調優實戰第五篇SQL
- 生產環境sql語句調優實戰第六篇SQL
- 生產環境sql語句調優實戰第八篇SQL
- 生產環境sql語句調優實戰第九篇SQL
- 生產環境sql語句調優實戰第七篇SQL
- 生產環境sql語句調優實戰第十篇SQL
- 生產環境大型sql語句調優實戰第一篇(一)SQL
- 生產環境大型sql語句調優實戰第一篇(二)SQL
- kafka生產環境規劃-kafka 商業環境實戰Kafka
- 使用hint來調優sql語句SQL
- 實戰生產環境vCenter HA配置(VCSA6.5)
- kafka生產者Producer引數設定及引數調優建議-kafka 商業環境實戰Kafka
- Eureka:生產環境優化總結。優化
- 生產系統pl/sql調優案例SQL
- MySQL調優篇 | SQL調優實戰(5)MySql
- PHP 效能分析第三篇: 效能調優實戰PHP
- SQL 語句調優_減少或者避免笛卡爾乘積的發生SQL
- oracle 對比sql語句執行環境OracleSQL
- 生產sql調優之統計資訊分析SQL
- 透過使用hint unnest調優sql語句SQL
- 通過使用hint unnest調優sql語句SQL
- 生產SQL語句突然變慢問題定位SQL
- 一條sql語句的建議調優分析SQL
- redmine生產環境搭建
- Django生產環境搭建Django
- 透過sql語句分析足彩(第三篇)SQL
- 通過sql語句分析足彩(第三篇)SQL
- SQL語句優化SQL優化
- 使用USE_HASH Hint調優一個SQL語句SQL
- 使用SQL調整顧問進行語句優化SQL優化
- HBase 核心元件協調及RegionServer JVM引數調優-OLAP商業環境實戰元件ServerJVM
- Vue 移動端專案生產環境的優化Vue優化
- MYSQL SQL語句優化MySql優化
- sql語句效能優化SQL優化
- SQL語句的優化SQL優化
- 求助:SQL語句優化SQL優化