sql級聯刪除

2021-09-06 16:31:20 字數 1415 閱讀 8931

原文:

sql級聯刪除

功能:在刪除主表時,自動刪除副表(外來鍵約束)相應內容

刪除包含

主鍵值的行的操作,該值由其它表的現有行中的外來鍵列引用。在級聯刪除中,還刪除其外鍵值引用刪除的主鍵值的所有行。

如:create database temp

gouse temp

gocreate table userinfo

(userid int identity(1,1) primary key ,

username varchar(20),  --使用者名稱

password varchar(20) not null --密碼

)create table userdetails

(id int identity(1,1) primary key,

name varchar(50) not null, --真實姓名

userid int,

foreign key (userid) references userinfo(userid) on delete cascade

)insert userinfo values ('ly','jeff')

insert userinfo values('wzq','wzqwzq')

insert userinfo values('lg','lglg')

insert userdetails values('李四',1)

insert userdetails values('王五',2)

insert userdetails values('劉六',3)

sqlserver 支援級聯更新和刪除

oracle 只支援級聯刪除

alter table 表名

add constraint 外鍵名

foreign key(欄位名) references 主表名(欄位名)

on delete cascade

語法:foreign key

(column[,...n])

references referenced_table_name[(ref_column[,...n])]

[on delete cascade]

[on update cascade]

注釋:column:列名

referenced_table_name:外來鍵參考的主鍵表名稱

ref_name:外來鍵要參考的表的主鍵列

on delete:刪除級聯

on update:更新級聯0 00

(請您對文章做出評價)

此時:delete from userinfo where userid = 1 就可刪除userinfo表和userdetails表的userid=1 的內容 

其它相關:

**:

SQL級聯更新和級聯刪除

alter table 表名 add constraint 約束名 foreign key 欄位名 references 主表名 欄位名 on delete cascade 語法 foreign key column n references referenced table name ref co...

SQL語句級聯刪除

如果想刪除主表的時候同時刪除字表資料,可以在建立外來鍵時設定on delete cascade 但是需要注意的是,這樣是比較危險的,盡量在業務中用程式控制刪除。create table a and b 主表 create table department dept id number 4 not n...

級聯刪除記錄 sql

就是要刪除含有被另外表作為外來鍵的表的內容 如何在table 員工基本資訊上建立刪除員工觸發器 注意 員工編號是 下面 工資表的外碼 表結構如下如下 create table 員工基本資訊 員工編號 varchar 15 primary key,姓名 varchar 8 not null,性別 ch...