SQLSERVER 外鍵約束 以及它的級聯刪除

sql server中建立外鍵約束有3中方式:
1.enterprise manager中,tables,design table,設置table的properties,
   可以建立constraint, reference key;
2.enterprise manager中,diagrams, new diagrams,建立兩個表的關係。
3.直接用transact sql語句。

三個方法都需要先建立數據表。
-- 創建表author :
create table [dbo].[author] (
 [id] [bigint] not null ,
 [authorname] [char] (10) null ,
 [address] [char] (480)  null ,
 [introduction] [ntext]  null
)

-- 創建表mybbs:
reate table [dbo].[mybbs] (
 [id] [bigint] identity (1, 1) not null ,
 [authorid] [bigint] not null ,
 [title] [char] (40)  null ,
 [date_of_created] [datetime] null ,
 [abstract] [char] (480)  null ,
 [content] [ntext]  null
)

設置表mybbs中的authorid爲外鍵,參照author表的id字段,直接使用transact sql語句,過程如下:
--增加表mybbs(authorid)的外鍵約束fk_mybbs_author,表mybbs中的authorid受表author中的主鍵id約束:
begin transaction
alter table dbo.mybbs add constraint fk_mybbs_author
  foreign key (authorid)
  references  dbo.author([id]) on update cascade on delete cascade

--刪除外鍵約束fk_mybbs_author:
--alter table dbo.mybbs drop constraint fk_mybbs_author
--rollback
commit transaction

上面on update cascade,on delete cascade兩個選項,指明以後author表的id字段有delete,update操作時,mybbs表中的id也會被級聯刪除或更新。如果沒有選中,是不可以對author表中已被mybbs表關聯的id進行update或者delete操作的。

文章整理:站長天空 網址:http://www.z6688.com/

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章