oracle唯一索引與普通索引的區別和聯系
區別:唯一索引unique index和一般索引normal index最大的差異是在索引列上增加一層唯一約束。添加唯一索引的數據列可以為空,但是只要尊在數據值,就必須是唯一的。
聯系:1)unique index就是額外添加唯一性的約束。該約束嚴格的保證索引列的取值是唯一的,這在一些數據列上的業務約束是很重要的功能。比如一個數據列,不能作為主鍵,而且允許為空,但是業務上要求唯一特性,這個時候用唯一性索引就是最好的旋轉。2)性能上兩者並無很大區別。
using index用法:
create primary key …. Using index :創建主鍵的時候同時將其設為索引,名稱與主鍵名稱相同。
在9i之后,在創建一個PK的時候,會自動創建一個與之對應的唯一索引。(因為某個字段如果被設置為Unique便會自動被設為索引)。如果不特別指定,這個索引的表空間和表的表空間是一樣的,但是不建議將兩者放在一起。
一般語句格式:
Create table test(name varchar(10)); Alter table test add primary key(name) tablespace tablespace1;
以上的處理方式有兩個不好的地方,第一是無法指定索引的名稱,第二無法指定索引存放的表空間。為了避免這種錯誤,最后按照以下方式來定義表格與表空間。
Create table test_uid(name varchar(10), Constraint test_uid_pk primary key(name) using index ( create unique index uid_test_uid on test_uid(name) tablespace tablespace2);
當然也可以部分處理。
Create table testone (name varchar(10 char)) tablespace1; Alter table testone add constraint pk_testine1 primary key(name) using index tablespace tablespace2;
作為一個好習慣,不要把索引和表格的數據放在同一個表空間。
一般索引單獨建一個表空間。
---------
本系列為最近一段時間學習oracle的學習筆記,記錄於此作為自身回顧,其中有的來的網絡,有的來的書籍,但時間已久,記不清哪些是引用,如是轉載但沒標注出,特意致歉。