1. 程式人生 > >關於 主鍵和外鍵

關於 主鍵和外鍵

tick not null 規則 更新 主鍵 join table 插入 out

SQL的主鍵和外鍵的作用:

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

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

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

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

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

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

一、什麽是主鍵、外鍵:

關系型數據庫中的一條記錄中有若幹個屬性,若其中某一個屬性組(註意是組)唯一標識一條記錄該屬性組就可以成為一個主鍵
比如:
學生表(學號,姓名,性別,班級)
其中每個學生的學號是唯一,學號就是一個主鍵
課程表(課程編號,課程名,學分)
其中課程編號是唯一

課程編號就是一個主鍵

成績表(學號,課程號,成績)
成績表中單一一個屬性無法唯一標識一條記錄,學號和課程號的組合才可以唯一標識一條記錄,所以學號和課程號的屬性組是一個主鍵
成績表中的學號不是成績表的主鍵,但它和學生表中的學號相對應,並且學生表中的學號是學生表的主鍵,則稱成績表中的學號是學生表的外鍵
同理 成績表中的課程號是課程表的外鍵

定義主鍵和外鍵主要是為了維護關系數據庫的完整性,總結一下:

1.主鍵是能確定一條記錄的唯一標識,比如,一條記錄包括身份正號,姓名,年齡。身份證號是唯一能確定你這個人的,其他都可能有重復,所以,身份證號是主鍵。

2.外鍵用於與另一張表的關聯。是能確定另一張表記錄的字段,用於保持數據的一致性。比如,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.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

-- 獲取表主外鍵約束

EXEC sp_helpconstraint ‘StuResults‘

-- 查詢表主鍵外鍵信息

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

sysobjects.name constraintName, sysobjects.xtype AS constraintType,

syscolumns.name AS columnName

FROM sysobjects INNER JOIN sysconstraints

ON sysobjects.xtype in(‘C‘, ‘F‘, ‘PK‘, ‘UQ‘, ‘D‘)

AND sysobjects.id = sysconstraints.constid

LEFT OUTER JOIN syscolumns ON sysconstraints.id = syscolumns.id

WHERE OBJECT_NAME(sysobjects.parent_obj)=‘StuResults‘

關於 主鍵和外鍵