日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

mysql觸發(fā)器trigger實(shí)例詳解

瀏覽:41日期:2023-10-05 09:23:55

MySQL好像從5.0.2版本就開始支持觸發(fā)器的功能了,本次博客就來介紹一下觸發(fā)器,首先還是談下概念性的東西吧:

什么是觸發(fā)器

觸發(fā)器是與表有關(guān)的數(shù)據(jù)庫對象,在滿足定義條件時(shí)觸發(fā),并執(zhí)行觸發(fā)器中定義的語句集合。觸發(fā)器的這種特性可以協(xié)助應(yīng)用在數(shù)據(jù)庫端確保數(shù)據(jù)的完整性。

舉個(gè)例子,比如你現(xiàn)在有兩個(gè)表【用戶表】和【日志表】,當(dāng)一個(gè)用戶被創(chuàng)建的時(shí)候,就需要在日志表中插入創(chuàng)建的log日志,如果在不使用觸發(fā)器的情況下,你需要編寫程序語言邏輯才能實(shí)現(xiàn),但是如果你定義了一個(gè)觸發(fā)器,觸發(fā)器的作用就是當(dāng)你在用戶表中插入一條數(shù)據(jù)的之后幫你在日志表中插入一條日志信息。當(dāng)然觸發(fā)器并不是只能進(jìn)行插入操作,還能執(zhí)行修改,刪除。

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

創(chuàng)建觸發(fā)器的語法如下:

CREATE TRIGGER trigger_name trigger_time trigger_event ON tb_name FOR EACH ROW trigger_stmttrigger_name:觸發(fā)器的名稱tirgger_time:觸發(fā)時(shí)機(jī),為BEFORE或者AFTERtrigger_event:觸發(fā)事件,為INSERT、DELETE或者UPDATEtb_name:表示建立觸發(fā)器的表明,就是在哪張表上建立觸發(fā)器trigger_stmt:觸發(fā)器的程序體,可以是一條SQL語句或者是用BEGIN和END包含的多條語句所以可以說MySQL創(chuàng)建以下六種觸發(fā)器:BEFORE INSERT,BEFORE DELETE,BEFORE UPDATEAFTER INSERT,AFTER DELETE,AFTER UPDATE

其中,觸發(fā)器名參數(shù)指要?jiǎng)?chuàng)建的觸發(fā)器的名字

BEFORE和AFTER參數(shù)指定了觸發(fā)執(zhí)行的時(shí)間,在事件之前或是之后

FOR EACH ROW表示任何一條記錄上的操作滿足觸發(fā)事件都會觸發(fā)該觸發(fā)器

創(chuàng)建有多個(gè)執(zhí)行語句的觸發(fā)器

CREATE TRIGGER 觸發(fā)器名 BEFORE|AFTER 觸發(fā)事件ON 表名 FOR EACH ROWBEGIN 執(zhí)行語句列表END

其中,BEGIN與END之間的執(zhí)行語句列表參數(shù)表示需要執(zhí)行的多個(gè)語句,不同語句用分號隔開

tips:一般情況下,mysql默認(rèn)是以 ; 作為結(jié)束執(zhí)行語句,與觸發(fā)器中需要的分行起沖突

為解決此問題可用DELIMITER,如:DELIMITER ||,可以將結(jié)束符號變成||

當(dāng)觸發(fā)器創(chuàng)建完成后,可以用DELIMITER ;來將結(jié)束符號變成;

mysql> DELIMITER ||mysql> CREATE TRIGGER demo BEFORE DELETE -> ON users FOR EACH ROW -> BEGIN -> INSERT INTO logs VALUES(NOW()); -> INSERT INTO logs VALUES(NOW()); -> END -> ||Query OK, 0 rows affected (0.06 sec)mysql> DELIMITER ;

上面的語句中,開頭將結(jié)束符號定義為||,中間定義一個(gè)觸發(fā)器,一旦有滿足條件的刪除操作

就會執(zhí)行BEGIN和END中的語句,接著使用||結(jié)束

最后使用DELIMITER ; 將結(jié)束符號還原

tigger_event:

mysql觸發(fā)器trigger實(shí)例詳解

load data語句是將文件的內(nèi)容插入到表中,相當(dāng)于是insert語句,而replace語句在一般的情況下和insert差不多,但是如果表中存在primary 或者unique索引的時(shí)候,如果插入的數(shù)據(jù)和原來的primary key或者unique相同的時(shí)候,會刪除原來的數(shù)據(jù),然后增加一條新的數(shù)據(jù),所以有的時(shí)候執(zhí)行一條replace語句相當(dāng)于執(zhí)行了一條delete和insert語句。

觸發(fā)器可以是一條SQL語句,也可以是多條SQL代碼塊,那如何創(chuàng)建呢?

DELIMITER $ #將語句的分隔符改為$BEGINsql1;sql2;...sqlnEND $DELIMITER ; #將語句的分隔符改回原來的分號';'在BEGIN...END語句中也可以定義變量,但是只能在BEGIN...END內(nèi)部使用:DECLARE var_name var_type [DEFAULT value] #定義變量,可指定默認(rèn)值SET var_name = value #給變量賦值NEW和OLD的使用:mysql觸發(fā)器trigger實(shí)例詳解

根據(jù)以上的表格,可以使用一下格式來使用相應(yīng)的數(shù)據(jù):

NEW.columnname:新增行的某列數(shù)據(jù)OLD.columnname:刪除行的某列數(shù)據(jù)說了這么多現(xiàn)在我們來創(chuàng)建一個(gè)觸發(fā)器吧!

現(xiàn)在有表如下:

用戶users表

CREATE TABLE `users` ( `id` int(11) unsigned NOT NULL AUTO_INCREMENT, `name` varchar(255) CHARACTER SET utf8mb4 DEFAULT NULL, `add_time` int(11) DEFAULT NULL, PRIMARY KEY (`id`), KEY `name` (`name`(250)) USING BTREE) ENGINE=MyISAM AUTO_INCREMENT=1000001 DEFAULT CHARSET=latin1;

日志logs表:

CREATE TABLE `logs` ( `Id` int(11) NOT NULL AUTO_INCREMENT, `log` varchar(255) DEFAULT NULL COMMENT ’日志說明’, PRIMARY KEY (`Id`)) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT=’日志表’;

需求是:當(dāng)在users中插入一條數(shù)據(jù),就會在logs中生成一條日志信息。

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

DELIMITER $CREATE TRIGGER user_log AFTER INSERT ON users FOR EACH ROWBEGINDECLARE s1 VARCHAR(40)character set utf8;DECLARE s2 VARCHAR(20) character set utf8;#后面發(fā)現(xiàn)中文字符編碼出現(xiàn)亂碼,這里設(shè)置字符集SET s2 = ' is created';SET s1 = CONCAT(NEW.name,s2); #函數(shù)CONCAT可以將字符串連接INSERT INTO logs(log) values(s1);END $DELIMITER ;

這里我用的navicat:

mysql觸發(fā)器trigger實(shí)例詳解

查看觸發(fā)器SHOW TRIGGERS語句查看觸發(fā)器信息

mysql觸發(fā)器trigger實(shí)例詳解

Tip:

上面我用的navicat直接創(chuàng)建,如果大家用的mysql front,name這里會有個(gè)區(qū)別,我們刪除剛才的觸發(fā)器,在Mysql front中測試

drop trigger user_log;#刪除觸發(fā)器

打開Mysql Front:

mysql觸發(fā)器trigger實(shí)例詳解

mysql front在編譯sql時(shí),不用定義結(jié)尾分隔符,修改后的sql直接這樣既可:

#DELIMITER $CREATE TRIGGER user_log AFTER INSERT ON users FOR EACH ROWBEGINDECLARE s1 VARCHAR(40)character set utf8;DECLARE s2 VARCHAR(20) character set utf8;SET s2 = ' is created';SET s1 = CONCAT(NEW.name,s2); #函數(shù)CONCAT可以將字符串連接INSERT INTO logs(log) values(s1);END #$#DELIMITER ;mysql觸發(fā)器trigger實(shí)例詳解

這里再??錄婦洌?/p>

tips:SHOW TRIGGERS語句無法查詢指定的觸發(fā)器

在triggers表中查看觸發(fā)器信息

SELECT * FROM information_schema.triggers;

mysql觸發(fā)器trigger實(shí)例詳解

結(jié)果顯示了所有觸發(fā)器的詳細(xì)信息,同時(shí),該方法可以查詢制定觸發(fā)器的詳細(xì)信息

SELECT * FROM information_schema.triggers WHERE TRIGGER_NAME=’user_log’;

tips:所有觸發(fā)器信息都存儲在information_schema數(shù)據(jù)庫下的triggers表中

可以使用SELECT語句查詢,如果觸發(fā)器信息過多,最好通過TRIGGER_NAME字段指定查詢

回到上面,我們創(chuàng)建好了觸發(fā)器,繼續(xù)在users中插入數(shù)據(jù)并查看數(shù)據(jù):

insert into users(name,add_time) values(’周伯通’,now());

好吧,我們再來查看一下logs表吧!

mysql觸發(fā)器trigger實(shí)例詳解

通過上面的例子,可以看到只需要在users中插入用戶的信息,日志會自動記錄到logs表中,這也許就是觸發(fā)器給我?guī)淼谋憬莅桑?

限制和注意事項(xiàng)

觸發(fā)器會有以下兩種限制:

1.觸發(fā)程序不能調(diào)用將數(shù)據(jù)返回客戶端的存儲程序,也不能使用采用CALL語句的動態(tài)SQL語句,但是允許存儲程序通過參數(shù)將數(shù)據(jù)返回觸發(fā)程序,也就是存儲過程或者函數(shù)通過OUT或者INOUT類型的參數(shù)將數(shù)據(jù)返回觸發(fā)器是可以的,但是不能調(diào)用直接返回?cái)?shù)據(jù)的過程。

2.不能再觸發(fā)器中使用以顯示或隱式方式開始或結(jié)束事務(wù)的語句,如START TRANS-ACTION,COMMIT或ROLLBACK。

注意事項(xiàng):MySQL的觸發(fā)器是按照BEFORE觸發(fā)器、行操作、AFTER觸發(fā)器的順序執(zhí)行的,其中任何一步發(fā)生錯(cuò)誤都不會繼續(xù)執(zhí)行剩下的操作,如果對事務(wù)表進(jìn)行的操作,如果出現(xiàn)錯(cuò)誤,那么將會被回滾,如果是對非事務(wù)表進(jìn)行操作,那么就無法回滾了,數(shù)據(jù)可能會出錯(cuò)。

總結(jié)

觸發(fā)器是基于行觸發(fā)的,所以刪除、新增或者修改操作可能都會激活觸發(fā)器,所以不要編寫過于復(fù)雜的觸發(fā)器,也不要增加過得的觸發(fā)器,這樣會對數(shù)據(jù)的插入、修改或者刪除帶來比較嚴(yán)重的影響,同時(shí)也會帶來可移植性差的后果,所以在設(shè)計(jì)觸發(fā)器的時(shí)候一定要有所考慮。

觸發(fā)器是一種特殊的存儲過程,它在插入,刪除或修改特定表中的數(shù)據(jù)時(shí)觸發(fā)執(zhí)行,它比數(shù)據(jù)庫本身標(biāo)準(zhǔn)的功能有更精細(xì)和更復(fù)雜的數(shù)據(jù)控制能力。

數(shù)據(jù)庫觸發(fā)器有以下的作用:

1.安全性。可以基于數(shù)據(jù)庫的值使用戶具有操作數(shù)據(jù)庫的某種權(quán)利。

# 可以基于時(shí)間限制用戶的操作,例如不允許下班后和節(jié)假日修改數(shù)據(jù)庫數(shù)據(jù)。

# 可以基于數(shù)據(jù)庫中的數(shù)據(jù)限制用戶的操作,例如不允許股票的價(jià)格的升幅一次超過10%。

2.審計(jì)。可以跟蹤用戶對數(shù)據(jù)庫的操作。

# 審計(jì)用戶操作數(shù)據(jù)庫的語句。

# 把用戶對數(shù)據(jù)庫的更新寫入審計(jì)表。

3.實(shí)現(xiàn)復(fù)雜的數(shù)據(jù)完整性規(guī)則

# 實(shí)現(xiàn)非標(biāo)準(zhǔn)的數(shù)據(jù)完整性檢查和約束。觸發(fā)器可產(chǎn)生比規(guī)則更為復(fù)雜的限制。與規(guī)則不同,觸發(fā)器可以引用列或數(shù)據(jù)庫對象。例如,觸發(fā)器可回退任何企圖吃進(jìn)超過自己保證金的期貨。

# 提供可變的缺省值。

4.實(shí)現(xiàn)復(fù)雜的非標(biāo)準(zhǔn)的數(shù)據(jù)庫相關(guān)完整性規(guī)則。觸發(fā)器可以對數(shù)據(jù)庫中相關(guān)的表進(jìn)行連環(huán)更新。例如,在auths表author_code列上的刪除觸發(fā)器可導(dǎo)致相應(yīng)刪除在其它表中的與之匹配的行。

# 在修改或刪除時(shí)級聯(lián)修改或刪除其它表中的與之匹配的行。

# 在修改或刪除時(shí)把其它表中的與之匹配的行設(shè)成NULL值。

# 在修改或刪除時(shí)把其它表中的與之匹配的行級聯(lián)設(shè)成缺省值。

# 觸發(fā)器能夠拒絕或回退那些破壞相關(guān)完整性的變化,取消試圖進(jìn)行數(shù)據(jù)更新的事務(wù)。當(dāng)插入一個(gè)與其主健不匹配的外部鍵時(shí),這種觸發(fā)器會起作用。例如,可以在books.author_code 列上生成一個(gè)插入觸發(fā)器,如果新值與auths.author_code列中的某值不匹配時(shí),插入被回退。

5.同步實(shí)時(shí)地復(fù)制表中的數(shù)據(jù)。

6.自動計(jì)算數(shù)據(jù)值,如果數(shù)據(jù)的值達(dá)到了一定的要求,則進(jìn)行特定的處理。例如,如果公司的帳號上的資金低于5萬元?jiǎng)t立即給財(cái)務(wù)人員發(fā)送警告數(shù)據(jù)。

到此這篇關(guān)于mysql觸發(fā)器trigger實(shí)例詳解的文章就介紹到這了,更多相關(guān)mysql觸發(fā)器實(shí)例內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: MySQL 數(shù)據(jù)庫
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产成人77亚洲精品www| 日本高清不卡一区二区三区视频| 特黄毛片在线观看| 日本在线高清| 日韩精品免费一区二区在线观看| 精品日韩一区| 国产精品xx| 视频福利一区| 激情久久久久久久| 国产精品88久久久久久| 亚洲精品电影| 天堂av一区| 中文字幕在线看片| 亚洲综合另类| 国产精品一区二区精品视频观看| 日本午夜精品一区二区三区电影 | 成人午夜国产| 老牛国产精品一区的观看方式| 日本视频一区二区| 日韩欧美综合| 亚洲区第一页| 欧美天堂视频| 日韩有吗在线观看| 亚洲黄色网址| 91亚洲无吗| 久久九九99| 久久av影院| 久久国产直播| 日韩va亚洲va欧美va久久| 韩国精品主播一区二区在线观看| 日韩国产欧美一区二区三区| 99成人在线视频| 国产精品久久亚洲不卡| 国产综合婷婷| 乱一区二区av| 日韩超碰人人爽人人做人人添| 日韩理论片av| 免费一区二区三区在线视频| aa亚洲婷婷| 国产欧洲在线| 国产精品.xx视频.xxtv| 在线看片一区| 亚洲va中文在线播放免费| 97se亚洲| 婷婷五月色综合香五月| 99国内精品| 91精品国产调教在线观看| 麻豆视频久久| 国产精品久久久久77777丨| 亚洲精品成人一区| 亚洲天堂免费| 久久www成人_看片免费不卡| 激情久久五月| 久久一区二区中文字幕| 夜鲁夜鲁夜鲁视频在线播放| 久久三级中文| 国模大尺度视频一区二区| 日韩精品视频在线看| 天堂va欧美ⅴa亚洲va一国产| 国产美女视频一区二区| 日本一区免费网站| 综合激情网...| 天海翼亚洲一区二区三区| 一区二区精品| 亚洲91在线| 国产精品99久久免费| 免费一级欧美片在线观看网站| 国产精品国码视频| 黄色欧美在线| 久久久精品久久久久久96| 日韩专区精品| 欧美日韩视频| 香蕉久久夜色精品国产| 亚洲视频播放| 日本伊人午夜精品| 久久激五月天综合精品| 久久国产精品免费精品3p| 鲁大师精品99久久久| 精品国产免费人成网站| 欧美午夜精品一区二区三区电影| 亚洲欧美久久久| 欧美日韩一区二区三区不卡视频| 麻豆精品久久久| 欧美日韩中文字幕一区二区三区| 久久国产成人| 免费看久久久| 在线国产一区| 日韩不卡一二三区| 国产激情在线播放| 天使萌一区二区三区免费观看| 国产精品一区二区三区av麻| 女生影院久久| 日本精品另类| 黄色国产精品| 久久免费福利| 综合一区二区三区| 国产传媒在线观看| 日韩精品社区| 国产综合激情| 成人日韩av| 亚洲精品在线a| 国产成人免费| 国产欧美啪啪| 日韩三区免费| 久久大逼视频| 久久精品国产网站| 日本中文字幕一区二区视频 | 欧美精品一区二区久久| 国产精品调教| 日韩激情av在线| 视频一区二区欧美| 激情综合自拍| 日韩在线免费| 韩国女主播一区二区三区| 日韩一区精品| 中文字幕亚洲在线观看| 不卡一二三区| 麻豆久久一区| 欧美黄色精品| 国产精品久久免费视频| 日韩不卡一二三区| 综合亚洲自拍| 亚洲深爱激情| 久久成人一区| 日韩一区欧美二区| 免费在线观看视频一区| 国产一区白浆| 99国产精品99久久久久久粉嫩| 999国产精品永久免费视频app| 五月天av在线| 91精品在线观看国产| 成人影视亚洲图片在线| 国产一区二区三区精品在线观看| 国产精品va| 正在播放日韩精品| 日本国产精品| 午夜欧美精品| 日韩毛片一区| 美女视频免费精品| 久久久精品五月天| 午夜亚洲福利在线老司机| 伊人久久大香伊蕉在人线观看热v| 蜜臀a∨国产成人精品| 日韩高清二区| 日本欧美国产| 日韩午夜一区| 97成人在线| 国产aⅴ精品一区二区四区| 国产va免费精品观看精品视频| 亚洲精品88| 蜜臀av在线播放一区二区三区| 国产视频一区二区在线播放| 日韩综合一区| 视频一区视频二区中文字幕| 国产精品久久久久久av公交车| av在线最新| 日韩一区二区三区在线看| 国产一区二区亚洲| 免费人成在线不卡| 久久精品国产99国产| 一级欧洲+日本+国产| 日本欧美一区二区在线观看| а√在线中文在线新版| 中文一区一区三区免费在线观| 国产精品久久久久久久久久齐齐| 久久久人人人| 国产福利资源一区| 视频精品一区二区| 亚洲精品福利电影| 国产欧美久久一区二区三区| 亚洲电影在线一区二区三区| 免费一级欧美片在线观看网站| 黄色日韩在线| 亚洲精品**中文毛片| 国产精品亲子伦av一区二区三区| 欧美日韩精品免费观看视频完整| 国产精品玖玖玖在线资源| 亚洲精品极品少妇16p| 日韩久久精品| 精品高清久久| 久久av资源| 国产欧美日韩亚洲一区二区三区| 亚洲一区二区三区高清| 日韩国产网站| 日韩久久精品网| 福利视频一区| 久久精品资源| 精品中文字幕一区二区三区| 日韩欧美在线精品| 蜜桃视频一区二区三区| 好吊日精品视频 | 免费精品视频| 亚洲欧美久久| 在线观看视频免费一区二区三区| 不卡中文字幕| 亚洲精品一区二区在线看| 免费av一区| 亚洲一区激情| av不卡免费看| 亚洲色图国产|