mysql 觸發器的使用 FOR INSERT,DELETE,UPDATE
觸發器語句中使用了兩種特殊的表:deleted 表和 inserted 表。
Deleted 表用於儲存 DELETE 和 UPDATE 語句所影響的行的複本。在執行 DELETE 或 UPDATE 語句時,行從觸發器表中刪除,並傳輸到 deleted 表中。Deleted 表和觸發器表通常沒有相同的行。
Inserted 表用於儲存 INSERT 和 UPDATE 語句所影響的行的副本。在一個插入或更新事務處理中,新建行被同時新增到 inserted 表和觸發器表中。Inserted 表中的行是觸發器表中新行的副本。
1.插入操作(Insert)
Inserted表有資料,Deleted表無資料
2.刪除操作(Delete)
Inserted表無資料,Deleted表有資料
3.更新操作(Update)
Inserted表有資料(新資料),Deleted表有資料(舊資料)
inserted、deleted
這是兩個虛擬表,inserted 儲存的是 insert 或 update 之後所影響的記錄形成的表,deleted 儲存的是 delete 或 update 之前所影響的記錄形成的表。
if not exists(select 1 from deleted)
begin /*deleted表無記錄,是新增*/
end
if not exists(select 1 from inserted)
begin /*inserted表無記錄,是刪除*/
end
create trigger Add_Del_Update on Table
for insert,update
as
if not exists(select 1 from deleted)
begin /*deleted表無記錄,是新增*/
end
if not exists(select 1 from inserted)
begin /*inserted表無記錄,是刪除*/
end
else
begin /*是更新*/ end
go
eg:
create trigger Add_Del_Update on tab1
for insert,update,delete
as
if not exists(select 1 from deleted)
begin /*deleted表無記錄,是新增*/
insert into tab2(dp,st)
select dp,st from inserted
end
if not exists(select 1 from inserted)
begin /*inserted表無記錄,是刪除*/
delete from tab2 where id in(select id from deleted)
end
else
begin /*是更新*/
update tab2 set tab2.dp=inserted.dp,tab2.st=inserted.st
from tab2,inserted where tab2.id=inserted.id
end
觸發器語句中使用了兩種特殊的表:deleted 表和 inserted 表。
Deleted 表用於儲存 DELETE 和 UPDATE 語句所影響的行的複本。在執行 DELETE 或 UPDATE 語句時,行從觸發器表中刪除,並傳輸到 deleted 表中。Deleted 表和觸發器表通常沒有相同的行。
Inserted 表用於儲存 INSERT 和 UPDATE 語句所影響的行的副本。在一個插入或更新事務處理中,新建行被同時新增到 inserted 表和觸發器表中。Inserted 表中的行是觸發器表中新行的副本。
1.插入操作(Insert)
Inserted表有資料,Deleted表無資料
2.刪除操作(Delete)
Inserted表無資料,Deleted表有資料
3.更新操作(Update)
Inserted表有資料(新資料),Deleted表有資料(舊資料)
inserted、deleted
這是兩個虛擬表,inserted 儲存的是 insert 或 update 之後所影響的記錄形成的表,deleted 儲存的是 delete 或 update 之前所影響的記錄形成的表。
if not exists(select 1 from deleted)
begin /*deleted表無記錄,是新增*/
end
if not exists(select 1 from inserted)
begin /*inserted表無記錄,是刪除*/
end
create trigger Add_Del_Update on Table
for insert,update
as
if not exists(select 1 from deleted)
begin /*deleted表無記錄,是新增*/
end
if not exists(select 1 from inserted)
begin /*inserted表無記錄,是刪除*/
end
else
begin /*是更新*/ end
go
eg:
create trigger Add_Del_Update on tab1
for insert,update,delete
as
if not exists(select 1 from deleted)
begin /*deleted表無記錄,是新增*/
insert into tab2(dp,st)
select dp,st from inserted
end
if not exists(select 1 from inserted)
begin /*inserted表無記錄,是刪除*/
delete from tab2 where id in(select id from deleted)
end
else
begin /*是更新*/
update tab2 set tab2.dp=inserted.dp,tab2.st=inserted.st
from tab2,inserted where tab2.id=inserted.id
end
觸發器語句中使用了兩種特殊的表:deleted表和 inserted 表。
Deleted 表用於儲存 DELETE 和 UPDATE 語句所影響的行的複本。在執行 DELETE 或 UPDATE 語句時,行從觸發器表中刪除,並傳輸到 deleted 表中。Deleted 表和觸發器表通常沒有相同的行。
Inserted 表用於儲存 INSERT 和 UPDATE 語句所影響的行的副本。在一個插入或更新事務處理中,新建行被同時新增到 inserted 表和觸發器表中。Inserted 表中的行是觸發器表中新行的副本。
1.插入操作(Insert)
Inserted表有資料,Deleted表無資料
2.刪除操作(Delete)
Inserted表無資料,Deleted表有資料
3.更新操作(Update)
Inserted表有資料(新資料),Deleted表有資料(舊資料)
inserted、deleted
這是兩個虛擬表,inserted 儲存的是 insert 或 update 之後所影響的記錄形成的表,deleted 儲存的是 delete 或 update 之前所影響的記錄形成的表。
if not exists(select 1 from deleted)
begin /*deleted表無記錄,是新增*/
end
if not exists(select 1 from inserted)
begin /*inserted表無記錄,是刪除*/
end
create trigger Add_Del_Update on Table
for insert,update
as
if not exists(select 1 from deleted)
begin /*deleted表無記錄,是新增*/
end
if not exists(select 1 from inserted)
begin /*inserted表無記錄,是刪除*/
end
else
begin /*是更新*/ end
go
eg:
create trigger Add_Del_Update on tab1
for insert,update,delete
as
if not exists(select 1 from deleted)
begin /*deleted表無記錄,是新增*/
insert into tab2(dp,st)
select dp,st from inserted
end
if not exists(select 1 from inserted)
begin /*inserted表無記錄,是刪除*/
delete from tab2 where id in(select id from deleted)
end
else
begin /*是更新*/
update tab2 set tab2.dp=inserted.dp,tab2.st=inserted.st
from tab2,inserted where tab2.id=inserted.id
end
注:此部落格是轉載的文字,非自己的作品,感覺很好就抄襲了,只是希望大家一起學習進步,