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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

SQL的主键和外键

發布時間:2023/12/10 数据库 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 SQL的主键和外键 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

SQL的主鍵和外鍵的作用

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'

轉載于:https://www.cnblogs.com/stockcrm/p/8597913.html

總結

以上是生活随笔為你收集整理的SQL的主键和外键的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。