1. 程式人生 > >mysql 觸發器的使用 FOR INSERT,DELETE,UPDATE

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

注:此部落格是轉載的文字,非自己的作品,感覺很好就抄襲了,只是希望大家一起學習進步,