首頁  >  文章  >  資料庫  >  oracle中什麼是索引

oracle中什麼是索引

青灯夜游
青灯夜游原創
2021-12-24 11:25:235954瀏覽

在oracle中,索引是一種供伺服器在表中快速查找一個行的資料庫結構,是建立在表的一列或多列上的輔助對象,目的是加快存取表中的資料。索引的作用:1、快速存取資料;2、既可以改善資料庫效能,又可以保證列值的唯一性等等。

oracle中什麼是索引

本教學操作環境:Windows7系統、Oracle 11g版、Dell G3電腦。

什麼是索引?

在oracle中,索引是一種供伺服器在表中快速尋找一行的資料庫結構。

  • 索引是建立在表格的一列或多列上的輔助對象,目的是加快存取表中的資料。

  • oracle 儲存索引的結構是B*數(平衡樹),而索引是由根節點、分支點和葉子點組成,上級索引區塊包含下級索引區塊的索引數據,葉節點包含索引資料和確定行實際位置的rowid。

在資料庫中建立索引主要有以下作用:

(1)快速存取資料。

(2)減少I/O操作

(3)既可以改善資料庫效能,又可以保證列值的唯一性。

(4)實作表格與資料表之間的參考完整性

(5)在使用orderby、groupby子句進行資料擷取時,利用索引可以減少排序與分組的時間。

什麼時候用:

  • 作為where後查詢條件的欄位適合建立索引。

什麼時候不用:

  • #重複欄位較多;

  • 不作為where後查詢條件的欄位;

  • 表中記錄較少。

怎麼用索引:

建立索引:

CREATE [UNIQUE] | [BITMAP] INDEX index_name  --unique表示唯一索引
ON table_name([column1 [ASC|DESC],column2    --bitmap,创建位图索引
[ASC|DESC],…] | [express])
[TABLESPACE tablespace_name]
[PCTFREE n1]                                 --指定索引在数据块中空闲空间
[STORAGE (INITIAL n2)]
[NOLOGGING]                                  --表示创建和重建索引时允许对表做DML操作,默认情况下不应该使用
[NOLINE]
[NOSORT];                                    --表示创建索引时不进行排序,默认不适用,如果数据已经是按照该索引顺序排列的可以使用

例如,

建立商品表:

-- Create table
create table TB_GOODS
(
  goods_id    VARCHAR2(64) not null,
  goods_name  VARCHAR2(256) not null,
  goods_price VARCHAR2(64) not null,
  status      VARCHAR2(1) not null
);

建立索引:

--这里unique可以省略,若省略则索引为非唯一索引
create index UI_tb_goods on tb_goods(goods_name);
--若使用unique则为唯一索引
create unique index un_tb_goods on tb_goods(goods_name);
--括号中添加两列则为组合索引
create unique index un2_tb_goods on tb_goods(goods_name,status);
--括号中添加三列,其顺序没有关系,效果是一样的
create unique index un3_tb_goods on tb_goods(goods_name,goods_price,status);

唯一索引的另一個作用,控制該列不能有相同值!

查詢索引:

select * from user_indexes where table_name='表名';
select * from user_ind_columns  where index_name='索引名';

#推薦教學:《Oracle教學

以上是oracle中什麼是索引的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn