欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL深入淺出掌握觸發(fā)器用法

 更新時(shí)間:2022年05月17日 09:28:54   作者:TimeFriends  
觸發(fā)器是SQLserver提供給程序員和數(shù)據(jù)分析員來(lái)保證數(shù)據(jù)完整性的一種方法,它是與表事件相關(guān)的特殊的存儲(chǔ)過(guò)程,事件是在 MySQL 5.1后引入的,有點(diǎn)類似操作系統(tǒng)的計(jì)劃任務(wù),但是周期性任務(wù)是內(nèi)置在MySQL服務(wù)端執(zhí)行的

MySQL觸發(fā)器

觸發(fā)器是一種特殊的存儲(chǔ)過(guò)程,觸發(fā)器和存儲(chǔ)過(guò)程一樣是一個(gè)能完成特定功能、存儲(chǔ)在數(shù)據(jù)庫(kù)服務(wù)器上的SQL片段,但是觸發(fā)器無(wú)需調(diào)用,當(dāng)對(duì)數(shù)據(jù)庫(kù)表中的數(shù)據(jù)執(zhí)行DML操作時(shí)自動(dòng)觸發(fā)這個(gè)SQL片段的執(zhí)行,無(wú)需手動(dòng)調(diào)用.

在MySQL中,只要執(zhí)行insert,update,delete操作是才能觸發(fā)觸發(fā)器的執(zhí)行

觸發(fā)器的這種特性可以協(xié)助應(yīng)用在數(shù)據(jù)庫(kù)端確保數(shù)據(jù)的完整性,日志記錄,數(shù)據(jù)校驗(yàn)等操作.

使用別名OLD和NEW來(lái)引用觸發(fā)器中發(fā)生變化的記錄內(nèi)容,這與其他的數(shù)據(jù)庫(kù)是相似的,現(xiàn)在觸發(fā)器還值支持行級(jí)觸發(fā),不支持語(yǔ)句級(jí)觸發(fā).

觸發(fā)器的特性

① 什么條件會(huì)觸發(fā): insert,delete,update

② 什么時(shí)候觸發(fā): 在增刪改前或者后

③ 觸發(fā)頻率: 針對(duì)每一行執(zhí)行

④ 觸發(fā)器定義在表上,附著在表上

創(chuàng)建觸發(fā)器

-- 創(chuàng)建只有一個(gè)執(zhí)行語(yǔ)句的觸發(fā)器
格式:
    create trigger 觸發(fā)器名 before|after 觸發(fā)事件
    on 表名 for each row
    執(zhí)行語(yǔ)句;

-- 創(chuàng)建有多個(gè)執(zhí)行語(yǔ)句的觸發(fā)器
格式:
    create trigger 觸發(fā)器名 before|after 觸發(fā)事件
    on 表名 for each row
    begin
        執(zhí)行語(yǔ)句列表
    end;

demo

-- 需求:當(dāng)user表添加一行數(shù)據(jù),則會(huì)自動(dòng)在user_log添加日志記錄

delimiter $$
create trigger trigger_test after insert
on user for each row
begin
    insert into user_logs values(1,now,'有新用戶增加');
end $$
delimiter;

觸發(fā)器操作-NEW和OLD

mysql中定義了new和old,用來(lái)表示觸發(fā)器的所在表中,觸發(fā)了觸發(fā)器的哪一行數(shù)據(jù),來(lái)引用觸發(fā)器中發(fā)生變化的記錄內(nèi)容,具體如下

觸發(fā)器類型觸發(fā)器類型NEW和OLD的使用
INSERT 型觸發(fā)器NEW 表示將要或者已經(jīng)新增的數(shù)據(jù)
UPDATE 型觸發(fā)器OLD 表示修改之前的數(shù)據(jù),NEW表示將要或者已經(jīng)修改后的數(shù)據(jù)
DELETE 型觸發(fā)器OLD 表示將要或者已經(jīng)刪除的數(shù)據(jù)

使用方法: NEW.columnName(columnName為相應(yīng)數(shù)據(jù)表某一列名)

demo

-- insert
	delimiter &&
	create trigger test1 after  insert
	on user for each row
	begin
		insert into user_logs values(1,now,concat('有新用戶增加,信息為',NEW.uid,NEW.username,NEW.password));
	end $$
	delimiter;
-- update
delimiter &&
	create trigger test2 after update
	on user for each row
	begin
		insert into user_logs values(1,now,concat('修改用戶,之前信息為',OLD.uid,OLD.username,OLD.password,'修改之后的信息為',NEW.uid,NEW.username,NEW.password));
	end $$
	delimiter;
-- delete
delimiter &&
	create trigger test3 after delete
	on user for each row
	begin
		insert into user_logs values(1,now,concat('有用戶刪除,信息為',OLD.uid,OLD.username,OLD.password));
	end $$
	delimiter;

觸發(fā)器-查看

show triggers;

觸發(fā)器-刪除

drop trigger if exists trigger_test;

觸發(fā)器的注意事項(xiàng)

① MYSQL中觸發(fā)器中不能對(duì)本表進(jìn)行insert,update,delete操作,以免遞歸循環(huán)觸發(fā)

② 盡量少使用觸發(fā)器,假設(shè)觸發(fā)器觸發(fā)每次執(zhí)行1s,insert table 500條數(shù)據(jù),那么就需要觸發(fā)500次觸發(fā)器,光是觸發(fā)器執(zhí)行的時(shí)間就要花費(fèi)500s,而insert 500條數(shù)據(jù)一共是1s,那么insert的效率就非常的低了.

③ 觸發(fā)器是針對(duì)每一行的,對(duì)增刪改非常頻繁的表上切記不要使用觸發(fā)器,因?yàn)樗麜?huì)非常消耗資源.

到此這篇關(guān)于MySQL深入淺出掌握觸發(fā)器用法的文章就介紹到這了,更多相關(guān)MySQL觸發(fā)器內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論