日本搞逼视频_黄色一级片免费在线观看_色99久久_性明星video另类hd_欧美77_综合在线视频

國內(nèi)最全I(xiàn)T社區(qū)平臺(tái) 聯(lián)系我們 | 收藏本站
阿里云優(yōu)惠2
您當(dāng)前位置:首頁 > 數(shù)據(jù)庫 > 數(shù)據(jù)庫應(yīng)用 > SQL 主鍵和外鍵約束

SQL 主鍵和外鍵約束

來源:程序員人生   發(fā)布時(shí)間:2015-08-13 08:42:02 閱讀次數(shù):4521次

SQL的主鍵和外鍵的作用:

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

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

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

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

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

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

 

 

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

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

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

2、主鍵、外鍵和索引的區(qū)分

定義:

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

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

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

作用:

主鍵--用來保證數(shù)據(jù)完全性

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

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

個(gè)數(shù):

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

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

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

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

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

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

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

StudentAge int, --int型的后面不需要接長度

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

)

--在創(chuàng)建表時(shí)就能夠?qū)ψ侄渭由鲜`:

create table Student

(

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

StudentName nvarchar(15) not null, --加非空束縛,不加"not null" 默許為:可以為空

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

StudentAge int DEFAULT ((0)), --加默許值束縛

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

)

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

-- 主鍵:

alter table 表名

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

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

--唯1束縛:

alter table 表名

add constraint UQ_字段名

unique (字段名)

--外鍵束縛:

alter table 表名

add constraint FK_字段名--"FK"為外鍵的縮寫

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

ON UPDATE CASCADE ON DELETE CASCADE

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

--檢查束縛:

alter table 表名

add constraint CK_字段名

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

--默許值束縛:

alter table 表名

add constraint DF_字段名

default '默許值' for 字段名--其中的'默許值'為你想要默許的值,注意'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ú)查詢表遞增字段

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'

來源聲明:  chenlaoyang博客   http://blog.csdn.net/chenlaoyang/article/details/8708980

生活不易,碼農(nóng)辛苦
如果您覺得本網(wǎng)站對您的學(xué)習(xí)有所幫助,可以手機(jī)掃描二維碼進(jìn)行捐贈(zèng)
程序員人生
------分隔線----------------------------
分享到:
------分隔線----------------------------
關(guān)閉
程序員人生
主站蜘蛛池模板: 日本在线视频一区 | 日韩欧美视频在线 | 国内自拍中文字幕 | 欧美高清在线观看 | 污视频网站在线免费观看 | 精品久久久久一区二区国产 | 国产精品欧美一区二区三区 | 黄色免费av | 亚洲在线视频观看 | 国产自产21区| 久久精品国产一区 | 在线天堂av | 日韩精品福利视频 | 国产美女一区二区三区 | 视频二区国产 | 91久久久久久久一区二区 | 日本一二三区在线 | 日韩欧美激情电影 | 欧美xx网站 | 国产一区二区三区久久 | 日韩视频在线一区二区 | 狠狠地操 | 欧美精品一区二区三区在线播放 | 久久久久久九九 | 久久成人综合 | 国产精品欧美一区二区 | 日韩大逼| 亚洲一区二区黄色 | 久久高清国产 | 国产在线日韩 | 天天搞夜夜 | 欧美一区二区三区免费看 | 黄色一毛片 | 精品国产乱码久久久久久影片 | 国产真实乱全部视频 | 国户精品久久久久久久久久久不卡 | 日韩精品国产精品 | 在线免费黄色 | 精品成人久久 | 成人在线一区二区三区 | 日韩久久久久久 |