1. 程式人生 > >資料庫的主鍵與外來鍵

資料庫的主鍵與外來鍵


一、定義
    主鍵:在資料表中可以作為唯一標識的欄位,不能有重複的,不允許為空。
           如:學生表(學號,姓名,性別,班級) 其中每個學生的學號是唯一的,學號
    就是一個主鍵 ;
    外來鍵:表的外來鍵是另一表的主鍵用於保持資料的一致性, 外來鍵可以有重複的, 可以是空值。

          如:A表中的一個欄位,是B表的主鍵,那他就可以是A表的外來鍵。

二、  主鍵、外來鍵和索引的區別 

        主鍵、外來鍵和索引的區別?

主鍵

外來鍵

索引

定義:

唯一標識一條記錄,不能有重複的,不允許為空

表的外來鍵是另一表的主鍵, 外來鍵可以有重複的, 可以是空值

該欄位沒有重複值,但可以有一個空值

作用:

用來保證資料完整性

用來和其他表建立聯絡用的

是提高查詢排序的速度

個數:

主鍵只能有一個

一個表可以有多個外來鍵

一個表可以有多個惟一索引

資料庫的約束有三種,實體完整性約束、參照完整性約束和使用者自定義約束。

    1.實體完整性約束指的是主鍵不能為空,如果主鍵為空了還怎麼唯一標識一條記錄。

    2.參照完整性約束,即外來鍵的約束,某一外來鍵的值必須在它引用的主鍵欄位中存在。如,學生表中專業編號屬性的值,必須都存於專業資訊表中的專業編號屬性中。想一想也就明白了,一個學生(大學生)怎麼可能屬於一個不存在的專業。

    3.使用者自定義完整性約束,指的是一些使用者自己設定的約束,例如欄位是否可以為空,欄位值的取值範圍(如:人的性別只能取男、女)。

例項:

一表的主鍵, 外來鍵可以有重複

例項:

createtable Student

(

StudentNointPRIMARY KEY IDENTITY(1,1),--加主鍵約束,還有標識列屬性(兩者構成實體完整性)

StudentNamenvarchar(15)notnull, --加非空約束,不加"not null" 預設為:可以為空

StudentSchooltext(20)FOREIGNKEY REFERENCES SchoolTable(SchoolName),--加外來鍵約束,格式:FOREIGN KEY REFERENCES 關聯的表名(欄位名)

StudentAgeintDEFAULT ((

0)),--加預設值約束

StudentSexnvarchar(2)CHECK(StudentSex=N''or StudentSex=N'')--加檢查約束,格式:check (條件表示式)

)

--如果在表建立好了以後再加約束,則格式分別為:

--主鍵:

altertable表名

addconstraint PK_欄位名--"PK"為主鍵的縮寫,欄位名為要在其上建立主鍵的欄位名,'PK_欄位名'就為約束名

primarykey(欄位名)--欄位名同上

--唯一約束:

altertable表名

addconstraint UQ_欄位名

unique(欄位名)

--外來鍵約束:

altertable表名

addconstraint FK_欄位名--"FK"為外來鍵的縮寫

foreignkey(欄位名)references關聯的表名(關聯的欄位名)--注意'關聯的表名''關聯的欄位名'

altertableAaddconstraint FK_Bforeignkey (ticket_no)referencesB(ticket_no)

altertableAaddconstraint FK_Cforeignkey (person_no)referencesC(person_no)

altertable成績表addconstraint FK_StudentNoforeignkey (StudentNo)references Student(StudentNo)

ONUPDATECASCADE ON DELETE CASCADE

級聯更新,級聯刪除,這樣在刪除主表Student時,成績表中該學生的所有成績都會刪除。

--檢查約束:

altertable表名

addconstraint CK_欄位名

check(條件表示式)--條件表示式中的條件用關係運算符連線

--預設值約束:

altertable表名

addconstraint DF_欄位名

default'預設值'for欄位名--其中的'預設值'為你想要預設的值,注意'for'

--刪除建立的約束:

altertable表名

dropconstraint約束名--約束名為你前面建立的如:PK_欄位這樣的約束名

--注意:如果約束是在建立表的時候建立的,則不能用命令刪除

--只能在'企業管理器'裡面刪除

--獲取SqlServer中表結構

SELECT syscolumns.name,systypes.name,syscolumns.isnullable,

syscolumns.length

FROM syscolumns,systypes

WHERE syscolumns.xusertype= systypes.xusertype

AND syscolumns.id=OBJECT_ID('Student')

--單獨查詢表遞增欄位

SELECT [name]FROM syscolumnsWHERE

id = OBJECT_ID(N'Student')ANDCOLUMNPROPERTY(id,name,'IsIdentity')=1

--獲取表主外來鍵約束

EXECsp_helpconstraint'StuResults'

--查詢表主鍵外來鍵資訊

SELECT sysobjects.id objectId,OBJECT_NAME(sysobjects.parent_obj) tableName,

sysobjects.name constraintName, sysobjects.xtypeAS constraintType,

syscolumns.nameAS columnName

FROM sysobjectsINNERJOIN sysconstraints

ON sysobjects.xtypein('C','F','PK', 'UQ','D')

AND sysobjects.id= sysconstraints.constid

LEFTOUTERJOIN syscolumnsON sysconstraints.id= syscolumns.id

WHEREOBJECT_NAME(sysobjects.parent_obj)='StuResults'