亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > 綜合 > 正文

SQL的主鍵和外鍵約束

2024-07-21 02:50:23
字體:
來源:轉載
供稿:網友
SQL的主鍵和外鍵約束SQL的主鍵和外鍵約束

轉自:http://www.cnblogs.com/ywb-lv/archive/2012/03/12/2391860.html

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'

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
九九热r在线视频精品| 色婷婷**av毛片一区| 久久69精品久久久久久久电影好| www.日韩系列| 在线播放日韩欧美| 国产精品偷伦免费视频观看的| 日韩有码在线电影| 欧美丰满片xxx777| 丰满岳妇乱一区二区三区| 91成人在线观看国产| 亲爱的老师9免费观看全集电视剧| 欧美一区二区影院| 成人网在线视频| 亚洲人成在线观| 精品国产一区二区三区久久狼5月| 精品国产美女在线| 亚洲欧美日韩国产中文| 精品国产一区二区三区在线观看| 亚洲欧美一区二区三区久久| 国产精品大陆在线观看| 久久频这里精品99香蕉| 久久伊人91精品综合网站| 91影院在线免费观看视频| 日韩电影在线观看免费| 精品伊人久久97| 26uuu亚洲伊人春色| 久久男人资源视频| 中文字幕亚洲一区在线观看| 深夜福利亚洲导航| 欧美人与性动交a欧美精品| 亚洲片在线观看| 成人免费视频xnxx.com| 色伦专区97中文字幕| 日韩精品视频免费| 国产精品福利在线观看网址| 亚洲电影中文字幕| 亚洲一区二区三区四区视频| 亚洲日本aⅴ片在线观看香蕉| 日韩亚洲第一页| 91在线视频免费| 深夜福利91大全| 色综合视频网站| 欧美色道久久88综合亚洲精品| 国产精品久久久av久久久| 91香蕉电影院| 成人免费视频网| 日韩中文字幕第一页| 日韩一区二区三区国产| 中文字幕国产亚洲2019| 午夜精品一区二区三区在线视频| 精品偷拍各种wc美女嘘嘘| 热久久免费视频精品| 国产v综合ⅴ日韩v欧美大片| 91精品在线观| 亚洲高清在线观看| 操人视频在线观看欧美| 日本精品久久中文字幕佐佐木| 91高清视频免费观看| 蜜月aⅴ免费一区二区三区| 亚洲qvod图片区电影| 久久偷看各类女兵18女厕嘘嘘| 欧美日产国产成人免费图片| 成人精品一区二区三区电影免费| 国产精品久久9| 国产精品电影网站| 精品国产成人在线| 欧美成在线观看| 亚洲欧美精品一区| 亚洲精品美女在线| 国产在线久久久| 国产亚洲日本欧美韩国| 91久久国产综合久久91精品网站| 久久久久久久97| 亚洲国语精品自产拍在线观看| 久久精品国产亚洲精品2020| 色99之美女主播在线视频| 久久久女女女女999久久| 国产精品综合不卡av| 日韩在线视频免费观看| 最近2019年日本中文免费字幕| 97av视频在线| 欧美在线性爱视频| 欧美亚洲视频一区二区| 日韩av黄色在线观看| 亚洲男人天天操| 国产精品扒开腿爽爽爽视频| 精品毛片三在线观看| 九色精品免费永久在线| 国产精品r级在线| 国产精品小说在线| 国产精品一区二区久久久| 精品人伦一区二区三区蜜桃网站| 茄子视频成人在线| 95av在线视频| 国产免费一区视频观看免费| 亚洲人成绝费网站色www| 亚洲一区二区中文| 精品久久久国产| 91中文精品字幕在线视频| 欧美精品中文字幕一区| 色婷婷亚洲mv天堂mv在影片| 亚洲欧洲xxxx| 亚洲美女黄色片| 亚洲女人被黑人巨大进入| 欧美亚洲激情视频| 欧美亚洲在线视频| 亚洲国产精品免费| **欧美日韩vr在线| 欧美日韩精品二区| 欧美一级大胆视频| 亚洲bt欧美bt日本bt| 亚洲www视频| 亚洲国产日韩欧美综合久久| 久久久久久久久久久人体| 国产欧美日韩中文字幕| 国产精品成人av在线| 欧美黑人性猛交| 992tv成人免费影院| 国产精品av网站| 国内精品免费午夜毛片| 国产在线精品自拍| 亚洲一区二区中文字幕| 欧美一区二区视频97| 国产精品色悠悠| 亚洲精品suv精品一区二区| 色偷偷噜噜噜亚洲男人| 国产精品久久久久999| 亚洲一区二区少妇| 成人在线观看视频网站| 欧美激情在线播放| 欧美电影免费观看大全| 精品亚洲永久免费精品| 91精品视频在线免费观看| 91大神在线播放精品| 日韩av综合中文字幕| 国产精品情侣自拍| 欧美另类极品videosbest最新版本| 亚洲欧美精品中文字幕在线| 欧美精品亚州精品| 日韩在线观看免费网站| 国产精品av免费在线观看| 在线视频国产日韩| 国产精品视频精品| 91夜夜揉人人捏人人添红杏| 国产精品欧美在线| 亚洲男人天堂网站| 亚洲国产精品一区二区久| 日韩欧美国产高清91| 欧美视频13p| 国产亚洲欧洲在线| 欧美裸体男粗大视频在线观看| 欧美性生交xxxxxdddd| 国产999精品| 日韩电影在线观看免费| 在线免费观看羞羞视频一区二区| 亚洲欧洲偷拍精品| 亚洲精品国产精品国产自| 亚洲欧洲美洲在线综合| 青草热久免费精品视频| 狠狠色狠狠色综合日日小说| 久久久久国产精品免费网站| 欧美另类xxx| 日韩av网址在线| 国产精品一区专区欧美日韩|