資料庫主鍵、外來鍵說明
外來鍵可以為NULL。只要引用的鍵不為PK,外來鍵就可以為NULLTop
FOREIGN KEY 約束並不僅僅只可以與另一表的 PRIMARY KEY 約束相連結,它還可以定義為引用另一表的 UNIQUE 約束。FOREIGN KEY 約束不允許空值,但是,如果任何組合 FOREIGN KEY 約束的列包含空值,則將跳過 FOREIGN KEY 約束的校驗。Top
外來鍵可以為空
SQL的主鍵和外來鍵的作用:
外來鍵取值規則:空值或參照的主鍵值。
(1)插入非空值時,如果主鍵表中沒有這個值,則不能插入。
(2)更新時,不能改為主鍵表中沒有的值。
(3)刪除主鍵表記錄時,你可以在建外來鍵時選定外來鍵記錄一起級聯刪除還是拒絕刪除。
(4)更新主鍵記錄時,同樣有級聯更新和拒絕執行的選擇。
簡而言之,SQL的主鍵和外來鍵就是起約束作用。
定義主鍵和外來鍵主要是為了維護關係資料庫的完整性,總結一下:
一、主鍵是能確定一條記錄的唯一標識,比如,一條記錄包括身份正號,姓名,年齡。身份證號是唯一能確定你這個人的,其他都可能有重複,所以,身份證號是主鍵。
外來鍵用於與另一張表的關聯。是能確定另一張表記錄的欄位,用於保持資料的一致性。比如,A表中的一個欄位,是B表的主鍵,那他就可以是A表的外來鍵。
二、主鍵、外來鍵和索引的區別
定義:
主鍵--
外來鍵--表的外來鍵是另一表的主鍵,外來鍵可以有重複的,可以是空值
索引--該欄位沒有重複值,但可以有一個空值
作用:
主鍵--用來保證資料完整性
外來鍵--用來和其他表建立聯絡用的
索引--是提高查詢排序的速度
個數:
主鍵--主鍵只能有一個
外來鍵--一個表可以有多個外來鍵
索引--一個表可以有多個唯一索引
建立SQL的主鍵和外來鍵約束的方法:
createtable Student --建表格式:create table自定義的表名
(--欄位名一般為有一定意義的英文
StudentNamenvarchar(15),-- 格式:欄位名型別
StudentAgeint, --int型的後面不需要接長度
StudentSexnvarchar(2)--最後一個欄位後面不要逗號
)
--在建立表時就可以對欄位加上約束:
createtable Student
(
StudentNoint PRIMARY KEY IDENTITY(1,1),--加主鍵約束,還有標識列屬性(兩者構成實體完整性)
StudentNamenvarchar(15)not null, --加非空約束,不加"not null" 預設為:可以為空
StudentSchooltext(20)FOREIGN KEY REFERENCES SchoolTable(SchoolName),--加外來鍵約束,格式:FOREIGN KEY REFERENCES 關聯的表名(欄位名)
StudentAgeint DEFAULT ((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 關聯的表名(關聯的欄位名)--注意'關聯的表名'和'關聯的欄位名'
altertable 表Aadd constraint FK_Bforeign key (ticket_no) references表B(ticket_no)
altertable 表Aadd constraint FK_Cforeign key (person_no) references表C(person_no)
altertable 成績表add constraint FK_StudentNoforeign key (StudentNo) references Student(StudentNo)
ONUPDATE CASCADE 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 syscolumns WHERE
id = OBJECT_ID(N'Student')AND COLUMNPROPERTY(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 sysobjectsINNER JOIN sysconstraints
ON sysobjects.xtypein('C','F', 'PK', 'UQ','D')
AND sysobjects.id= sysconstraints.constid
LEFTOUTER JOIN syscolumnsON sysconstraints.id= syscolumns.id
WHEREOBJECT_NAME(sysobjects.parent_obj)='StuResults'