日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 运维知识 > 数据库 >内容正文

数据库

SQL的主键和外键约束

發(fā)布時(shí)間:2025/4/5 数据库 40 豆豆
生活随笔 收集整理的這篇文章主要介紹了 SQL的主键和外键约束 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

SQL的主鍵和外鍵的作用:

?? 外鍵取值規(guī)則:空值或參照的主鍵值。

(1)插入非空值時(shí),如果主鍵表中沒(méi)有這個(gè)值,則不能插入。

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

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

(4)更新主鍵記錄時(shí),同樣有級(jí)聯(lián)更新和拒絕執(zhí)行的選擇。

簡(jiǎn)而言之,SQL的主鍵和外鍵就是起約束作用。

?

?

定義主鍵和外鍵主要是為了維護(hù)關(guān)系數(shù)據(jù)庫(kù)的完整性,總結(jié)一下:

一、主鍵是能確定一條記錄的唯一標(biāo)識(shí),比如,一條記錄包括身份正號(hào),姓名,年齡。身份證號(hào)是唯一能確定你這個(gè)人的,其他都可能有重復(fù),所以,身份證號(hào)是主鍵。

外鍵用于與另一張表的關(guān)聯(lián)。是能確定另一張表記錄的字段,用于保持?jǐn)?shù)據(jù)的一致性。比如,A表中的一個(gè)字段,是B表的主鍵,那他就可以是A表的外鍵。

?

二、主鍵、外鍵和索引的區(qū)別

?

定義:

主鍵--唯一標(biāo)識(shí)一條記錄,不能有重復(fù)的,不允許為空

外鍵--表的外鍵是另一表的主鍵, 外鍵可以有重復(fù)的, 可以是空值

索引--該字段沒(méi)有重復(fù)值,但可以有一個(gè)空值

?

作用:

主鍵--用來(lái)保證數(shù)據(jù)完整性

外鍵--用來(lái)和其他表建立聯(lián)系用的

索引--是提高查詢(xún)排序的速度

?

個(gè)數(shù):

主鍵--主鍵只能有一個(gè)

外鍵--一個(gè)表可以有多個(gè)外鍵

索引--一個(gè)表可以有多個(gè)唯一索引

?

創(chuàng)建SQL的主鍵和外鍵約束的方法:

?

create table Student --建表格式:create table 自定義的表名

( --字段名一般為有一定意義的英文

StudentName nvarchar(15), -- 格式:字段名類(lèi)型()括號(hào)里面的是允許輸入的長(zhǎng)度

StudentAge int, --int型的后面不需要接長(zhǎng)度

StudentSex nvarchar(2) --最后一個(gè)字段后面不要逗號(hào)

)

?

--在創(chuàng)建表時(shí)就可以對(duì)字段加上約束:

create table Student

(

StudentNo int PRIMARY KEY IDENTITY(1,1), --加主鍵約束,還有標(biāo)識(shí)列屬性(兩者構(gòu)成實(shí)體完整性)

StudentName nvarchar(15) not null, --加非空約束,不加"not null" 默認(rèn)為:可以為空

StudentSchool text(20) FOREIGN KEY REFERENCES SchoolTable(SchoolName), --加外鍵約束,格式:FOREIGN KEY REFERENCES 關(guān)聯(lián)的表名(字段名)

StudentAge int DEFAULT ((0)), --加默認(rèn)值約束

StudentSex nvarchar(2) CHECK(StudentSex=N'男' or StudentSex=N'女') --加檢查約束,格式:check (條件表達(dá)式)

)

?

--如果在表創(chuàng)建好了以后再加約束,則格式分別為:

?

-- 主鍵:

alter table 表名

add constraint PK_字段名--"PK"為主鍵的縮寫(xiě),字段名為要在其上創(chuàng)建主鍵的字段名,'PK_字段名'就為約束名

primary key (字段名) --字段名同上

?

--唯一約束:

alter table 表名

add constraint UQ_字段名

unique (字段名)

?

--外鍵約束:

alter table 表名

add constraint FK_字段名--"FK"為外鍵的縮寫(xiě)

foreign key (字段名) references 關(guān)聯(lián)的表名(關(guān)聯(lián)的字段名) --注意'關(guān)聯(lián)的表名'和'關(guān)聯(lián)的字段名'

?

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 成績(jī)表 add constraint FK_StudentNo foreign key (StudentNo) references Student (StudentNo)

ON UPDATE CASCADE ON DELETE CASCADE

級(jí)聯(lián)更新,級(jí)聯(lián)刪除,這樣在刪除主表Student時(shí),成績(jī)表中該學(xué)生的所有成績(jī)都會(huì)刪除。

?

?

--檢查約束:

alter table 表名

add constraint CK_字段名

check (條件表達(dá)式) --條件表達(dá)式中的條件用關(guān)系運(yùn)算符連接

?

--默認(rèn)值約束:

alter table 表名

add constraint DF_字段名

default '默認(rèn)值' for 字段名--其中的'默認(rèn)值'為你想要默認(rèn)的值,注意'for'

?

--刪除創(chuàng)建的約束:

alter table 表名

drop constraint 約束名--約束名為你前面創(chuàng)建的如:PK_字段這樣的約束名

--注意:如果約束是在創(chuàng)建表的時(shí)候創(chuàng)建的,則不能用命令刪除

--只能在'企業(yè)管理器'里面刪除

?

?

?

?

?

-- 獲取SqlServer中表結(jié)構(gòu)

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

syscolumns.length

FROM syscolumns,systypes

WHERE syscolumns.xusertype = systypes.xusertype

AND syscolumns.id = OBJECT_ID('Student')

?

-- 單獨(dú)查詢(xún)表遞增字段

SELECT [name] FROM syscolumns WHERE

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

?

-- 獲取表主外鍵約束

EXEC sp_helpconstraint 'StuResults'

?

?

-- 查詢(xún)表主鍵外鍵信息

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'

轉(zhuǎn)載于:https://www.cnblogs.com/tiger95/p/6635962.html

總結(jié)

以上是生活随笔為你收集整理的SQL的主键和外键约束的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。