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

詳解MySQL數(shù)據(jù)庫之觸發(fā)器

 更新時間:2020年09月30日 08:43:14   作者:奧辰  
這篇文章主要介紹了MySQL數(shù)據(jù)庫之觸發(fā)器的相關(guān)資料,幫助大家更好的理解和使用MySQL,感興趣的朋友可以了解下

1 引言

本文是對MySQL中觸發(fā)器的總結(jié),從觸發(fā)器概念出發(fā),結(jié)合實例對創(chuàng)建觸發(fā)器、使用觸發(fā)器、刪除觸發(fā)器進(jìn)行介紹。

2 觸發(fā)器簡介

MySQL觸發(fā)器和存儲過程一樣,都是嵌入到MySQL的一段程序。觸發(fā)器是由事件來觸發(fā)某個操作,這些事件包括INSERT、UPDATE、DELETE。如果定義了觸發(fā)器,當(dāng)數(shù)據(jù)庫執(zhí)行這些語句的時候就會激活觸發(fā)器執(zhí)行相應(yīng)的操作,觸發(fā)程序是與表有關(guān)的命令數(shù)據(jù)庫對象,當(dāng)表上出現(xiàn)特定事件,將激活該對象。

  觸發(fā)器是一個特殊的存儲過程,不同的是,執(zhí)行存儲過程要使用call語句來調(diào)用,而觸發(fā)器的執(zhí)行不需要用call來調(diào)用,也不需要手工啟動,只要當(dāng)一個預(yù)定義的事件發(fā)生,觸發(fā)器就會被MySQL自動調(diào)用。觸發(fā)器可以查詢其他表,而且可以包含復(fù)雜的SQL語句。

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

 ?。?)創(chuàng)建只有一條執(zhí)行語句的觸發(fā)器

  語法結(jié)構(gòu)如下:

CREATE TRIGGER trigger_name trigger_time trigger_event ON table_name FOR EACH ROW trigger_stmt

  trigger_name:用戶自定義的觸發(fā)器名稱;

  trigger_time:標(biāo)識觸發(fā)事件,可以指定為before(時間發(fā)生前執(zhí)行)或after(事件發(fā)生后執(zhí)行);

  trigger_event:標(biāo)識觸發(fā)事件,包括INSERT、UPDATE、DELETE;

  table_name:觸發(fā)器建立在哪個表上;

  trigger_stmt:觸發(fā)器執(zhí)行語句。

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

語法結(jié)構(gòu)如下:

CREATE TRIGGER trigger_name trigger_time trigger_event ON table_name FOR EACH ROW

 BEGIN

  語句執(zhí)行列表

 END

當(dāng)觸發(fā)器有至少一條的執(zhí)行語句時,多條執(zhí)行語句需要用BEGIN和END包裹,分別表示整個代碼塊的開始和結(jié)束。

  為演示觸發(fā)器操作,我們先創(chuàng)建一下三個數(shù)據(jù)表:

create table tb_student(

   id int PRIMARY key auto_increment,

   name varchar(10)

);

create table tb_before_trigger(

   id int PRIMARY key auto_increment,

   num int ,

   time_now datetime NULL DEFAULT CURRENT_TIMESTAMP

);

create table tb_after_trigger(

   id int PRIMARY key auto_increment,

   num int ,

   time_now datetime NULL DEFAULT CURRENT_TIMESTAMP

);

  示例1:創(chuàng)建一個名為before_trigger的觸發(fā)器,該觸發(fā)器會在每次對表tb_student執(zhí)行insert操作前觸發(fā),觸發(fā)時會往before_trigger表插入一條包含tb_student表總記錄數(shù)的記錄。

delimiter //

create trigger before_trigger before insert

   on tb_student for each row

   begin

     insert into tb_before_trigger (num) select count(*) from tb_student;

   end

   //

delimiter ;

  示例2:創(chuàng)建一個名為after_trigger的觸發(fā)器,該觸發(fā)器會在每次對表tb_student執(zhí)行insert操作前觸發(fā),觸發(fā)時會向before_trigger表插入一條包含tb_student表總記錄數(shù)的記錄。

delimiter //

create trigger after_trigger after insert

   on tb_student for each row

   begin

     insert into tb_after_trigger (num) select count(*) from tb_student;

   end

   //

delimiter ;

  來測試一下示例1和示例2中創(chuàng)建的觸發(fā)器,往tb_student表中插入一條數(shù)據(jù)(插入前3個表沒有任何記錄):

insert into tb_student (name) values('zhangsan');

  插入后,查看三個表中數(shù)據(jù):

  tb_student表:

  tb_before_trigger表:

  tb_after_trigger表:

  可以看到,在tb_student表執(zhí)行insert操作后,另外兩個表也分別更新了記錄,tb_before_trigger表num值為0,證明在tb_student執(zhí)行insert操作前插入的;tb_after_trigger表num值為1,證明在tb_student執(zhí)行insert操作后插入的——這就是before與after的區(qū)別。

  對于其他條件觸發(fā)器,使用方法與示例1和示例2類似,本文不在演示。

4 查看觸發(fā)器

 ?。?)show triggers語句

  通過show triggers語句可以查看示例1和示例2中創(chuàng)建的觸發(fā)器:

show triggers;

  輸出結(jié)果:

 ?。?)在triggers表中查看觸發(fā)器

  在information_schema數(shù)據(jù)庫的triggers表中存放在MySQL數(shù)據(jù)庫中的所有觸發(fā)器,可以通過查詢語句進(jìn)行查看:

select * from information_schema.triggers where trigger_name = 'before_trigger' ;

  輸出結(jié)果:

  當(dāng)不指定查詢條件時,即是指查看所有觸發(fā)器信息。

5 刪除觸發(fā)器

  使用DROP TRIGGER語句可以刪除觸發(fā)器,基本語法結(jié)構(gòu)如下:

DROP TRIGGER [schema_name] trigger_name

  其中,schema_name表示數(shù)據(jù)庫名稱,是可選參數(shù),如果省略則表示從當(dāng)前數(shù)據(jù)庫中刪除觸發(fā)器。

  示例3:刪除示例1中創(chuàng)建的觸發(fā)器before_trigger

drop trigger before_trigger;

6 總結(jié)

在某些時候,觸發(fā)器可以起到錦上添花的作用,但是,觸發(fā)器的效率并不高,所以還是盡量少用。

作者:奧辰

Github:https://github.com/ChenHuabin321

以上就是詳解MySQL數(shù)據(jù)庫之觸發(fā)器的詳細(xì)內(nèi)容,更多關(guān)于MySQL 觸發(fā)器的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • mysql千萬級數(shù)據(jù)量根據(jù)索引優(yōu)化查詢速度的實現(xiàn)

    mysql千萬級數(shù)據(jù)量根據(jù)索引優(yōu)化查詢速度的實現(xiàn)

    這篇文章主要介紹了mysql千萬級數(shù)據(jù)量根據(jù)索引優(yōu)化查詢速度的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03
  • 簡述mysql監(jiān)控組復(fù)制

    簡述mysql監(jiān)控組復(fù)制

    這篇文章主要介紹了mysql監(jiān)控組復(fù)制的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)mysql,感興趣的朋友可以了解下
    2020-08-08
  • MySQL8.0與MySQL5.7的區(qū)別詳解

    MySQL8.0與MySQL5.7的區(qū)別詳解

    MySQL8.0是2018年4月20日發(fā)布的全球最受歡迎的開源數(shù)據(jù)庫的一個非常令人興奮的新版本,下面這篇文章主要給大家介紹了關(guān)于MySQL8.0與MySQL5.7區(qū)別的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-01-01
  • MySQL啟動錯誤解決方法

    MySQL啟動錯誤解決方法

    本文給大家分享的是mysql啟動時報錯的排查過程及方法,非常實用,有相同問題的小伙伴可以來參考下
    2016-12-12
  • B-樹的插入過程介紹

    B-樹的插入過程介紹

    今天小編就為大家分享一篇關(guān)于B-樹的插入過程介紹,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-01-01
  • mysql獲取版本的幾種方法實現(xiàn)

    mysql獲取版本的幾種方法實現(xiàn)

    本文主要介紹了mysql獲取版本的方法實現(xiàn),主要介紹了三種方法,包含SELECT VERSION(),SHOW VARIABLES和命令行,具有一定的參考價值,感興趣的可以了解一下
    2024-06-06
  • Win10安裝MySQL8壓縮包版的教程

    Win10安裝MySQL8壓縮包版的教程

    這篇文章主要介紹了Win10安裝MySQL8壓縮包版的教程,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-04-04
  • mysql多表連接查詢實例講解

    mysql多表連接查詢實例講解

    本篇文章中給大家通過實例代碼講述了mysql多表連接查詢的方法,有需要的朋友們可以參考學(xué)習(xí)下。
    2018-10-10
  • SQL中的distinct的使用方法

    SQL中的distinct的使用方法

    這篇文章主要介紹SQL中的distinct的使用方法,distinct用來查詢不重復(fù)記錄的條數(shù),即用distinct來返回不重復(fù)字段的條數(shù),文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2023-05-05
  • MySQL 按指定字段自定義列表排序的實現(xiàn)

    MySQL 按指定字段自定義列表排序的實現(xiàn)

    下面小編就為大家?guī)硪黄狹ySQL 按指定字段自定義列表排序的實現(xiàn)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-03-03

最新評論