Я хотел бы улучшить производительность следующего в агрегированном запросе.Обновление производительности в сводном запросе
На T_Search_Detail с 30 миллионами записей ниже запрос занимает 12 секунд для выполнения? можно ли его лучше написать, предложения по повышению производительности?
Explain Plan:
Execution Plan
----------------------------------------------------------
Plan hash value: 651646209
--------------------------------------------------------------------------------------------------
| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |
--------------------------------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | 3 | 42 | 27948 (1)| 00:05:36 |
| 1 | SORT GROUP BY | | 3 | 42 | 27948 (1)| 00:05:36 |
| 2 | VIEW | | 56 | 784 | 27947 (1)| 00:05:36 |
| 3 | HASH GROUP BY | | 56 | 1344 | 27947 (1)| 00:05:36 |
|* 4 | TABLE ACCESS BY INDEX ROWID| T_SEARCH_DETAIL | 898 | 21552 | 27946 (1)| 00:05:36 |
|* 5 | INDEX RANGE SCAN | INDEX_CREATE_DT | 1254K| | 3451 (1)| 00:00:42 |
--------------------------------------------------------------------------------------------------
Predicate Information (identified by operation id):
---------------------------------------------------
4 - filter("TSD"."MATCH_SOURCE" IS NOT NULL AND "TSD"."MATCH_TYPE" IS NOT NULL AND
"TSD"."MATCH_TYPE" LIKE '%Exact%')
5 - access("TSD"."CREATE_DT">=TO_DATE(' 2012-12-11 00:00:00', 'syyyy-mm-dd
hh24:mi:ss') AND "TSD"."CREATE_DT"<TO_DATE(' 2013-04-23 00:00:00', 'syyyy-mm-dd
hh24:mi:ss'))
Таблица DDL:
Этот запрос использует две таблицы T_Search и T_Search_detail с foreign_key как match_id.
SELECT ms,
SUM(ct)
FROM (SELECT tsd.match_source ms,
tsd.match_type mt,
COUNT(tsd.search_id) ct
FROM t_search ts,
t_search_detail tsd
WHERE tsd.match_source IS NOT NULL
AND tsd.match_type IS NOT NULL
AND ts.match_id = tsd.match_id
AND tsd.match_type LIKE '%Exact%'
AND
(
tsd.create_dt >= to_date('12/11/2012', 'MM/DD/YYYY')
AND tsd.create_dt < (to_date('04/22/2013', 'MM/DD/YYYY')+1)
)
GROUP BY tsd.match_source,
tsd.match_type
)
GROUP BY ms
ORDER BY ms DESC
Вы должны предоставить план объяснения и определение таблицы, как минимум, в противном случае никто не сможет разумно помочь вам. – Ben
Можете ли вы предоставить некоторые показатели производительности? Время, память и т. Д. –
Просьба также указать размеры таблиц и информацию об индексах. –