要查看Oracle收集的統計信息,您可以使用DBMS_STATS包中的過程和函數
連接到Oracle數據庫: 使用SQL*Plus或其他Oracle客戶端工具(如Toad、SQL Developer等)連接到目標數據庫。
查看表統計信息: 使用DBMS_STATS.GET_TABLE_STATS過程獲取表的統計信息。例如,要查看名為"employees"的表的統計信息,請執行以下命令:
DECLARE
v_numrows NUMBER;
v_blocks NUMBER;
v_empty_blocks NUMBER;
v_avgspace NUMBER;
v_chaincnt NUMBER;
v_avgrowlen NUMBER;
v_avgspcpi NUMBER;
BEGIN
DBMS_STATS.GET_TABLE_STATS(
ownname => 'YOUR_SCHEMA_NAME',
tabname => 'EMPLOYEES',
numrows => v_numrows,
blocks => v_blocks,
empty_blocks => v_empty_blocks,
avgspace => v_avgspace,
chaincnt => v_chaincnt,
avgrowlen => v_avgrowlen,
avgspcpi => v_avgspcpi
);
DBMS_OUTPUT.PUT_LINE('Number of Rows: ' || v_numrows);
DBMS_OUTPUT.PUT_LINE('Blocks: ' || v_blocks);
DBMS_OUTPUT.PUT_LINE('Empty Blocks: ' || v_empty_blocks);
DBMS_OUTPUT.PUT_LINE('Average Space: ' || v_avgspace);
DBMS_OUTPUT.PUT_LINE('Chain Count: ' || v_chaincnt);
DBMS_OUTPUT.PUT_LINE('Average Row Length: ' || v_avgrowlen);
DBMS_OUTPUT.PUT_LINE('Average Space per Index: ' || v_avgspcpi);
END;
/
將’YOUR_SCHEMA_NAME’替換為實際的模式名稱。
查看索引統計信息: 使用DBMS_STATS.GET_INDEX_STATS過程獲取索引的統計信息。例如,要查看名為"emp_idx"的索引的統計信息,請執行以下命令:
DECLARE
v_numrows NUMBER;
v_leaf_blocks NUMBER;
v_distinct_keys NUMBER;
v_avgleafblocksperkey NUMBER;
v_avgdatakeysperleaf NUMBER;
BEGIN
DBMS_STATS.GET_INDEX_STATS(
ownname => 'YOUR_SCHEMA_NAME',
indname => 'EMP_IDX',
numrows => v_numrows,
leaf_blocks => v_leaf_blocks,
distinct_keys => v_distinct_keys,
avgleafblocksperkey => v_avgleafblocksperkey,
avgdatakeysperleaf => v_avgdatakeysperleaf
);
DBMS_OUTPUT.PUT_LINE('Number of Rows: ' || v_numrows);
DBMS_OUTPUT.PUT_LINE('Leaf Blocks: ' || v_leaf_blocks);
DBMS_OUTPUT.PUT_LINE('Distinct Keys: ' || v_distinct_keys);
DBMS_OUTPUT.PUT_LINE('Average Leaf Blocks per Key: ' || v_avgleafblocksperkey);
DBMS_OUTPUT.PUT_LINE('Average Data Keys per Leaf: ' || v_avgdatakeysperleaf);
END;
/
將’YOUR_SCHEMA_NAME’替換為實際的模式名稱。
查看分區表和索引的統計信息: 對于分區表和索引,您可以使用DBMS_STATS.GET_PARTITION_STATS過程來獲取每個分區的統計信息。
這些方法將幫助您查看Oracle收集的統計信息。請注意,這些統計信息可能需要定期更新以確保查詢優化器可以生成最佳的執行計劃。