[轉]SQL的主鍵和外鍵約束

來源:互聯網
上載者:User

標籤:style   blog   ar   color   sp   for   on   資料   div   

SQL的主鍵和外鍵的作用:

   外鍵取值規則:空值或參照的主索引值。

(1)插入非空值時,如果主鍵表中沒有這個值,則不能插入。

(2)更新時,不能改為主鍵表中沒有的值。

(3)刪除主鍵表記錄時,你可以在建外鍵時選定外鍵記錄一起串聯刪除還是拒絕刪除。

(4)更新主鍵記錄時,同樣有串聯更新和拒絕執行的選擇。

簡而言之,SQL的主鍵和外鍵就是起約束作用。

 

 

關係型資料庫中的一條記錄中有若干個屬性,若其中某一個屬性群組(注意是組)能唯一標識一條記錄,該屬性群組就可以成為一個主鍵。

比如:

學生表(學號,姓名,性別,班級)

    其中每個學生的學號是唯一的,學號就是一個主鍵;

課程表(課程編號,課程名,學分)

    其中課程編號是唯一的,課程編號就是一個主鍵;

成績表(學號,課程號,成績)

    成績表中單一一個屬性無法唯一標識一條記錄,學號和課程號的組合才可以唯一標識一條記錄,所以,學號和課程號的屬性群組是一個主鍵。

 

成績表中的學號不是成績表的主鍵,但它和學生表中的學號相對應,並且學生表中的學號是學生表的主鍵,則稱成績表中的學號是學生表的外鍵;同理,成績表中的課程號是課程表的外鍵。

 

定義主鍵和外鍵主要是為了維護關聯式資料庫的完整性,總結一下:

一、主鍵是能確定一條記錄的唯一標識,比如,一條記錄包括身份正號,姓名,年齡。社會安全號碼是唯一能確定你這個人的,其他都可能有重複,所以,社會安全號碼是主鍵。

外鍵用於與另一張表的關聯。是能確定另一張表記錄的欄位,用於保持資料的一致性。比如,A表中的一個欄位,是B表的主鍵,那他就可以是A表的外鍵。

 

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

 

定義:

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

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

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

 

作用:

 主鍵--用來保證資料完整性

 外鍵--用來和其他表建立聯絡用的

 索引--是提高查詢排序的速度

 

個數:

 主鍵--主鍵只能有一個

 外鍵--一個表可以有多個外鍵

 索引--一個表可以有多個唯一索引

 

 

 

 

建立SQL的主鍵和外鍵約束的方法:

create table Student --建表格式:create table 自訂的表名( --欄位名一般為有一定意義的英文StudentName nvarchar(15), -- 格式:欄位名類型()括弧裡面的是允許輸入的長度StudentAge int, --int型的後面不需要接長度StudentSex nvarchar(2) --最後一個欄位後面不要逗號) --在建立表時就可以對欄位加上約束:create table Student(StudentNo int PRIMARY KEY IDENTITY(1,1), --加主鍵約束,還有識別欄位屬性(兩者構成實體完整性)StudentName nvarchar(15) not null, --加非空約束,不加"not null" 預設為:可以為空白StudentSchool text(20) FOREIGN KEY REFERENCES SchoolTable(SchoolName), --加外鍵約束,格式:FOREIGN KEY REFERENCES 關聯的表名(欄位名)StudentAge int DEFAULT ((0)), --加預設值約束StudentSex nvarchar(2) CHECK(StudentSex=N‘男‘ or StudentSex=N‘女‘) --加檢查約束,格式:check (條件運算式)) --如果在表建立好了以後再加約束,則格式分別為: -- 主鍵:alter table 表名add constraint PK_欄位名--"PK"為主鍵的縮寫,欄位名為要在其上建立主鍵的欄位名,‘PK_欄位名‘就為約束名primary key (欄位名) --欄位名同上 --唯一約束:alter table 表名add constraint UQ_欄位名unique (欄位名) --外鍵約束:alter table 表名add constraint FK_欄位名--"FK"為外鍵的縮寫foreign key (欄位名) references 關聯的表名(關聯的欄位名) --注意‘關聯的表名‘和‘關聯的欄位名‘ alter table 表A add constraint FK_B foreign key (ticket_no) references 表B(ticket_no)alter table 表A add constraint FK_C foreign key (person_no) references 表C(person_no) alter table 成績表 add constraint FK_StudentNo foreign key (StudentNo) references Student (StudentNo)ON UPDATE CASCADE ON DELETE CASCADE串聯更新,串聯刪除,這樣在刪除主表Student時,成績表中該學生的所有成績都會刪除。  --檢查約束:alter table 表名add constraint CK_欄位名check (條件運算式) --條件運算式中的條件用關係運算子串連 --預設值約束:alter table 表名add constraint DF_欄位名default ‘預設值‘ for 欄位名--其中的‘預設值‘為你想要預設的值,注意‘for‘ --刪除建立的約束:alter table 表名drop constraint 約束名--約束名為你前面建立的如:PK_欄位這樣的約束名--注意:如果約束是在建立表的時候建立的,則不能用命令刪除--只能在‘企業管理器‘裡面刪除     -- 擷取SqlServer中表結構SELECT syscolumns.name,systypes.name,syscolumns.isnullable,syscolumns.lengthFROM syscolumns,systypesWHERE syscolumns.xusertype = systypes.xusertypeAND syscolumns.id = OBJECT_ID(‘Student‘) -- 單獨查詢表遞增欄位SELECT [name] FROM syscolumns WHEREid = OBJECT_ID(N‘Student‘) AND COLUMNPROPERTY(id,name,‘IsIdentity‘)=1 -- 擷取表主外鍵約束EXEC sp_helpconstraint ‘StuResults‘  -- 查詢表主鍵外鍵資訊SELECT sysobjects.id objectId,OBJECT_NAME(sysobjects.parent_obj) tableName,sysobjects.name constraintName, sysobjects.xtype AS constraintType,syscolumns.name AS columnNameFROM sysobjects INNER JOIN sysconstraintsON sysobjects.xtype in(‘C‘, ‘F‘, ‘PK‘, ‘UQ‘, ‘D‘)AND sysobjects.id = sysconstraints.constidLEFT OUTER JOIN syscolumns ON sysconstraints.id = syscolumns.idWHERE OBJECT_NAME(sysobjects.parent_obj)=‘StuResults‘

 

[轉]SQL的主鍵和外鍵約束

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.