程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> Oracle數據庫 >> Oracle數據庫基礎 >> 概述Oracle Unique約束

概述Oracle Unique約束

編輯:Oracle數據庫基礎

Oracle還是比較常用的,於是我研究了一下Oracle Unique約束,在這裡拿出來和大家分享一下,希望對大家有用。如果某個約束只作用於單獨的字段,即可以在字段級定義約束,也可以在表級定義約束,但如果某個約束作用於多個字段,必須在表級定義約束

◆在定義約束時可以通過CONSTRAINT關鍵字為約束命名,如果沒有指定,Oracle將自動為約束建立默認的名稱定義primary key約束(單個字段)

  1. create table employees (empno number(5) primary key,...) 

指定約束名

  1. create table employees (empno number(5) constraint emp_pk primary key,...) 

定義primary key約束(多個字段,在表級定義約束)

  1. create table employees  
  2. (empno number(5),  
  3. deptno number(3) not null,  
  4. constraint emp_pk primary key(empno,deptno)  
  5. using index tablespace indx  
  6. storage (initial 64K  
  7. next 64K  
  8. )  

Oracle自動會為具有PRIMARY KEY約束的字段(主碼字段)建立一個唯一索引和一個NOT NULL約束,定義PRIMARY KEY約束時可以為它的索引指定存儲位置和存儲參數

  1. alter table employees add primary key (empno)  
  2. alter table employees add constraint emp_pk primary key (empno)  
  3. alter table employees add constraint emp_pk primary key (empno,deptno)  
  4. not null約束(只能在字段級定義NOT NULL約束,在同一個表中可以定義多個NOT NULL約束)  
  5. alter table employees modify deptno not null/null 

Unique約束

  1. create table employees  
  2. ( empno number(5),  
  3. ename varchar2(15),  
  4. phone varchar2(15),  
  5. email varchar2(30) unique,  
  6. deptno number(3) not null,  
  7. constraint emp_ename_phone_uk unique (ename,phone)  
  8. )  
  9. alter table employees  
  10. add constraint emp_uk unique(ename,phone)  
  11. using index tablespace indx 

定義了Oracle Unique約束的字段中不能包含重復值,可以為一個或多個字段定義Oracle Unique約束,因此,Unique即可以在字段級也可以在表級定義,在Oracle Unique約束的字段上可以包含空值.

foreign key約束

◆定義為FOREIGN KEY約束的字段中只能包含相應的其它表中的引用碼字段的值或者NULL值

◆可以為一個或者多個字段的組合定義FOREIGN KEY約束

◆定義了FOREIGN KEY約束的外部碼字段和相應的引用碼字段可以存在於同一個表中,這種情況稱為"自引用"

◆對同一個字段可以同時定義FOREIGN KEY約束和NOT NULL約束

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved