Oracle數(shù)據(jù)庫索引查詢方式
一、索引基礎概念
??索引類型與適用場景??
??B樹索引??:最常用,適合高基數(shù)列(唯一值多)的等值或范圍查詢。
??位圖索引??:適用于低基數(shù)列(如性別、狀態(tài)),常用于數(shù)據(jù)倉庫。
??函數(shù)索引??:基于列的函數(shù)表達式創(chuàng)建(如UPPER(name)),優(yōu)化帶函數(shù)的查詢。
??復合索引??:多列組合,列順序至關重要(高選擇性列在前)。
??反向索引??:優(yōu)化模糊查詢(如LIKE ‘%abc’)。
?? 索引的優(yōu)缺點??
- 優(yōu)點??:加速數(shù)據(jù)檢索,減少磁盤I/O。
- 缺點??:占用存儲空間;降低DML操作(增刪改)效率;需定期維護。
二、索引查詢方法
1. ??查看索引元信息??
??表的所有索引??
SELECT index_name, index_type, uniqueness FROM dba_indexes WHERE table_name = 'EMPLOYEES';
??索引的列信息??
SELECT column_name, column_position FROM dba_ind_columns WHERE index_name = 'IDX_DEPT_FIRSTNAME';
索引所在的表信息分析
SELECT i.index_name, i.table_name, ic.column_name, ic.column_position FROM dba_indexes i JOIN dba_ind_columns ic ON i.index_name = ic.index_name WHERE i.index_name = 'IDX_NAME'; --按索引名稱條件查詢
2. ??分析索引使用情況??
??監(jiān)控索引使用頻率??
SELECT * FROM v$index_usage; -- 跟蹤索引是否被有效利用,需 12c 以上版本管理員權限
??檢查未使用索引??
SELECT index_name FROM dba_indexes WHERE index_name NOT IN (SELECT name FROM v$index_usage);
索引碎片與空間效率
-- 1.查詢當前用戶創(chuàng)建的索引碎片率
SELECT index_name,
blevel,
leaf_blocks,
clustering_factor,
ROUND((leaf_blocks * 100) / NULLIF(clustering_factor, 0), 2) AS fragmentation_ratio
FROM (
SELECT di.index_name,
di.blevel,
di.leaf_blocks,
di.clustering_factor
FROM dba_indexes di
JOIN dba_tables dt ON di.table_name = dt.table_name
WHERE dt.owner = USER -- 只查詢當前用戶創(chuàng)建的表
AND di.clustering_factor > 1
) t
WHERE (leaf_blocks * 100) / clustering_factor > 30; -- >30%表示需重建
-- 2.查詢 索引所在的表信息分析
SELECT i.index_name, i.table_name, ic.column_name, ic.column_position
FROM dba_indexes i
JOIN dba_ind_columns ic ON i.index_name = ic.index_name
WHERE i.index_name = 'IDX_NAME'; --按索引名稱條件查詢
--3.重建碎片化索引??
ALTER INDEX IDX_NAME REBUILD ONLINE; -- IDX_NAME 為索引名稱
3. ??執(zhí)行計劃分析??
EXPLAIN PLAN FOR SELECT * FROM employees WHERE department_id = 10; SELECT * FROM TABLE(DBMS_XPLAN.DISPLAY);
關鍵指標??:
- INDEX RANGE SCAN:索引有效使用。
- FULL TABLE SCAN:可能缺失或未使用索引。
三、優(yōu)化索引空間的策略?
1. 創(chuàng)建索引
CREATE UNIQUE INDEX idx_user_name ON user_info(user_name) TABLESPACE idx_tbs COMPRESS NOLOGGING;
2. 重建碎片化索引??
ALTER INDEX IDX_OLD REBUILD ONLINE; -- 減少空間碎片,提升查詢效率
3. ??調整存儲參數(shù)??
ALTER INDEX IDX_LARGE PCTFREE 10; -- 降低空閑空間預留,壓縮索引體積
4. 刪除冗余索引??
DROP INDEX IDX_REDUNDANT; -- 通過監(jiān)控確認使用率低的索引
5. ??啟用高級壓縮??(僅限企業(yè)版)
ALTER INDEX IDX_BIG COMPRESS ADVANCED LOW; -- 節(jié)省30-50%空間
四、關鍵監(jiān)控指標??
| ?? | 指標?? ?? | 查看方式?? ?? | 優(yōu)化閾值?? |
|---|---|---|---|
| ?? | 索引大小?? | dba_segments.bytes | >表空間的20%需優(yōu)化 |
| ?? | 碎片率?? | (leaf_blocks / clustering_factor) * 100 | >30%需重建 |
| ?? | 使用頻率?? | v$index_usage.user_reads | 近30天無讀操作可刪 |
| ?? | 分區(qū)均勻性?? | dba_index_partitions.bytes 的方差值 | 方差>50%需調整分區(qū) |
五、 查詢實踐案例
1. ??查詢 Oracle 表空間大小
-- 表空間使用率監(jiān)控(含自動擴展狀態(tài))
SELECT
df.tablespace_name "Tablespace",
df.total_mb,
df.total_mb - fs.free_mb "Used_MB",
fs.free_mb "Free_MB",
ROUND((df.total_mb - fs.free_mb) / df.total_mb * 100, 2) Pct_Used, -- 使用率
autoext "AutoExt"
FROM
(SELECT tablespace_name,
SUM(bytes)/1024/1024 total_mb,
MAX(DECODE(autoextensible,'YES','Y','N')) autoext
FROM dba_data_files
GROUP BY tablespace_name) df
JOIN
(SELECT tablespace_name,
SUM(bytes)/1024/1024 free_mb
FROM dba_free_space
GROUP BY tablespace_name) fs
ON df.tablespace_name = fs.tablespace_name
WHERE ROUND((df.total_mb - fs.free_mb) / df.total_mb * 100, 2) > 80 -- 僅顯示>80%使用率的表空間
ORDER BY Pct_Used DESC;
結果示例:
| Tablespace | total_mb | Used_MB | Free_MB | Pct_Used | AutoExt |
|---|---|---|---|---|---|
| TBS_PICP | 3548 | 3309 | 239 | 93 | .26 |
| TBS_PICP_NEW | 4048 | 3523 | 525 | 87 | .03 |
2. 查詢 Oracle 索引使用情況
替換 PICP_FORMAL(表用戶) 和 T_USER_INFO(表名稱 需大寫)
-- 替換 PICP_FORMAL 和 T_USER_INFO(需大寫)
WITH table_info AS (
SELECT
t.owner,
t.table_name,
t.tablespace_name,
t.num_rows,
t.avg_row_len,
ROUND((t.num_rows * t.avg_row_len) / 1024 / 1024, 2) AS estimated_data_size_mb,
ROUND(SUM(s.bytes) / 1024 / 1024, 2) AS actual_table_size_mb
FROM dba_tables t
JOIN dba_segments s ON t.owner = s.owner AND t.table_name = s.segment_name
WHERE t.owner = 'PICP_FORMAL'
AND t.table_name = 'T_USER_INFO'
AND s.segment_type = 'TABLE'
GROUP BY t.owner, t.table_name, t.tablespace_name, t.num_rows, t.avg_row_len
),
index_info AS (
SELECT
i.index_name,
ROUND(s.bytes / 1024 / 1024, 2) AS index_size_mb,
i.uniqueness
FROM dba_indexes i
JOIN dba_segments s ON i.owner = s.owner AND i.index_name = s.segment_name
WHERE i.table_owner = 'PICP_FORMAL'
AND i.table_name = 'T_USER_INFO'
AND s.segment_type = 'INDEX'
)
SELECT
-- 表基本信息
ti.table_name,
ti.tablespace_name,
ti.num_rows,
ti.avg_row_len,
ti.estimated_data_size_mb,
ti.actual_table_size_mb,
-- 索引詳細信息
ii.index_name,
ii.index_size_mb,
ii.uniqueness,
-- 索引匯總信息
ROUND(SUM(ii.index_size_mb) OVER (), 2) AS total_index_size_mb,
ROUND((SUM(ii.index_size_mb) OVER () / ti.actual_table_size_mb) * 100, 2) AS index_to_table_ratio_percent
FROM table_info ti
LEFT JOIN index_info ii ON 1=1
ORDER BY ii.index_size_mb DESC NULLS LAST;
示例結果如下:
| TABLE_NAME | TABLESPACE_NAME | NUM_ROWS | AVG_ROW_LEN | ESTIMATED_DATA_SIZE_MB | ACTUAL_TABLE_SIZE_MB | INDEX_NAME | INDEX_SIZE_MB | UNIQUENESS | TOTAL_INDEX_SIZE_MB | INDEX_TO_TABLE_RATIO_PERCENT |
|---|---|---|---|---|---|---|---|---|---|---|
| T_USER_INFO | TBS_PICP_NEW | 636046 | 37 | 262.55 | 271 | PK_T_USER_ID | 45 | UNIQUE | 371 | 37.09 |
| T_USER_INFO | TBS_PICP_NEW | 636046 | 37 | 262.55 | 271 | IDX_USER_NAME | 28 | NONUNIQUE | 71 | 37.09 |
總結
以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
oracle數(shù)據(jù)庫添加或刪除一列的sql語句
需要注意的一點,如果要修改的表,不是當前的用戶的表,那么就需要添加上用戶的名稱。以及有修改此表的權限2012-05-05
如何保持Oracle數(shù)據(jù)庫的優(yōu)良性能
如何保持Oracle數(shù)據(jù)庫的優(yōu)良性能...2007-03-03
MSSQL與Oracle數(shù)據(jù)庫事務隔離級別與鎖機制對比
事務隔離級別是并發(fā)控制的整體解決方案,其實際上是綜合利用各種類型的鎖和行版本控制,來解決并發(fā)問題。鎖是數(shù)據(jù)庫并發(fā)控制的內部機制,是基礎。對用戶來說,只有當事務隔離級別無法解決一些并發(fā)問題和需求時,才有必要在語句中手動設置鎖。2014-08-08
Oracle數(shù)據(jù)庫rownum和row_number的不同點
在Oracle中,有一個很有趣的東西,那就是rownum。當你從某個表中查詢數(shù)據(jù)的時候,返回的結果集中都會帶有rownum這個字段,而且有時候也可以使用rownum進行一些條件查詢2015-11-11
navicat使用Oracle創(chuàng)建庫以及用戶超詳細教程
本文介紹如何使用Navicat連接Oracle數(shù)據(jù)庫,步驟包括準備工作、新建連接、輸入用戶名和密碼、測試連接、建立庫和用戶、授權以及測試的相關資料,需要的朋友可以參考下2024-09-09
Oracle創(chuàng)建主鍵自增表(sql語句實現(xiàn))及觸發(fā)器應用
主鍵自增在插入數(shù)據(jù)的時候是很實用的,可以獲取并操作返回的插入記錄的ID,接下來介紹Oracle如何創(chuàng)建主鍵自增表,感興趣的你可以了解下,就當是鞏固知識,希望此文對你有所幫助2013-01-01

