偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

MySQL觸發(fā)器的正確使用與案例分析

數(shù)據(jù)庫 MySQL
我們今天主要和大家一起分享的是MySQL觸發(fā)器的實(shí)際使用詳細(xì)說明與實(shí)際案例分析,下面就是文章的具體內(nèi)容描述,望你會(huì)有所收獲。

以下的文章主要向大家講述的是MySQL觸發(fā)器的實(shí)際使用詳細(xì)說明與實(shí)際案例分析,同時(shí)本文也列舉了一些在MySQL觸發(fā)器的實(shí)際式操作中的代碼,以下就是文章的詳細(xì)內(nèi)容介紹,望大家借鑒。

觸發(fā)器案例

 

  1. mysql> select * from a; +------+------+------+ 
    | id | name | age | +------+------+------+ 
    | 1 | A1 | 10 | | 2 | A2 | 20 | +------+------+------+ 
    mysql
    > select * from b; +------+------+------+ 
    | rid | id | age | +------+------+------+ | 5 | 2 | 20 | +------+------+------+  

希望在表a的age字段更新的時(shí)候能夠觸發(fā)表b相應(yīng)的age字段也更新:

 

如:

 

 

  1. update a set ageage=age+1 where id=2;  

 

相關(guān)的表變?yōu)椋?/p>

 

  1. mysql> select * from a; +------+------+------+ 
    | id | name | age | +------+------+------+ 
    | 1 | A1 | 10 | | 2 | A2 | 21 | +------+------+------+ 
    mysql
    > select * from b; +------+------+------+ 
    | rid | id | age | +------+------+------+ | 5 | 2 | 21 | +------+------+------+ 

正確的寫法

觸發(fā)器代碼

 

  1. CREATE TRIGGER bbs1 AFTER UPDATE ON a FOR EACH ROW update b set age=NEW.age where id=NEW.id;  

MySQL觸發(fā)器

 

觸發(fā)器的概念:“在數(shù)據(jù)庫中為響應(yīng)一個(gè)特殊表格中的某些事件而自動(dòng)執(zhí)行的程序代碼。”(Wikipedia)說得簡單一些,它是在一個(gè)特殊的數(shù)據(jù)庫事件,如INSERT或DELETE發(fā)生時(shí),自動(dòng)激活的一段代碼。觸發(fā)器可方便地用于日志記錄、對(duì)單個(gè)表格到其他鏈接式表格進(jìn)行自動(dòng)的“層疊式”更改、或保證對(duì)表格關(guān)系進(jìn)行自動(dòng)更新。

當(dāng)一個(gè)新整數(shù)值增加到數(shù)據(jù)庫域中時(shí),自動(dòng)更新運(yùn)行的總數(shù)的代碼段是一個(gè)觸發(fā)器。自動(dòng)記錄對(duì)一個(gè)特殊數(shù)據(jù)庫表格所作更改的SQL命令塊也是一個(gè)觸發(fā)器實(shí)例。

觸發(fā)器是MySQL 5.x的新功能,隨著5.x代碼樹新版本的出現(xiàn),這一功能也逐漸得到改善。在本文中,我將簡單介紹如何定義并使用觸發(fā)器,查看觸發(fā)器狀態(tài),并如何在使用完畢后刪除觸發(fā)器。我還將為你展示一個(gè)觸發(fā)器在現(xiàn)實(shí)世界中的應(yīng)用實(shí)例,并檢驗(yàn)它對(duì)數(shù)據(jù)庫記錄的改變。

 

例子

 

通過簡單(雖然是人為的)實(shí)例來說明是了解MySQL觸發(fā)器應(yīng)用的***辦法。首先我們建立兩個(gè)單域的表格。一個(gè)表格中為姓名列表(表格名:data),另一個(gè)表格中是所插入字符的字符數(shù)(表格名:chars)。我希望在data表格中定義一個(gè)觸發(fā)器,每次在其中插入一個(gè)新姓名時(shí),chars表格中運(yùn)行的總數(shù)就會(huì)根據(jù)新插入記錄的字符數(shù)目進(jìn)行自動(dòng)更新。

 

 

 

  1. mysql> CREATE TABLE data (name VARCHAR(255)); 
    Query OK, 0 rows affected (0.09 sec) mysql
    > CREATE TABLE chars (count INT(10)); 
    Query OK, 0 rows affected (0.07 sec) mysql
    > INSERT INTO chars (count) VALUES (0); 
    Query OK, 1 row affected (0.00 sec) mysql
    > CREATE TRIGGER t1 
    AFTER INSERT ON data FOR EACH ROW UPDATE chars SET 
    countcount = count + CHAR_LENGTH(NEW.name); Query OK, 0 rows affected (0.01 sec)  

     

 

理解上面代碼的關(guān)鍵在于CREATE TRIGGER命令,它被用來定義一個(gè)新觸發(fā)器。這個(gè)命令建立一個(gè)新觸發(fā)器,假定的名稱為t1,每次有一個(gè)新記錄插入到data表格中時(shí),t1就被激活。

 

在這個(gè)觸發(fā)器中有兩個(gè)重要的子句:

 

AFTER INSERT子句表明觸發(fā)器在新記錄插入data表格后激活。

 

UPDATE chars SET count = count + CHAR_LENGTH(NEW.name)子句表示觸發(fā)器激活后執(zhí)行的SQL命令。在本例中,該命令表明用新插入的data.name域的字符數(shù)來更新 chars.count欄。這一信息可通過內(nèi)置的MySQL函數(shù)CHAR_LENGTH()獲得。

 

放在源表格域名前面的NEW關(guān)鍵字也值得注意。這個(gè)關(guān)鍵字表明觸發(fā)器應(yīng)考慮域的new值(也就是說,剛被插入到域中的值)。MySQL還支持相應(yīng)的OLD前綴,可用它來指域以前的值。

 

你可以通過調(diào)用SHOW TRIGGER命令來檢查觸發(fā)器是否被激活。

 

 

 

  1. mysql> SHOW TRIGGERS; *************************** 
    1. row *************************** 
    ?Trigger: t1 ?Event: INSERT ?Table: data Statement: 
    UPDATE chars SET 
    countcount = count + CHAR_LENGTH(NEW.name) 
    Timing: AFTER ?Created: NULL ql_mode: 1 row in set (0.01 sec)  

 

激活觸發(fā)器后,開始對(duì)它進(jìn)行測(cè)試。試著在data表格中插入幾個(gè)記錄:

 

 

 

  1. mysql> INSERT INTO data (name) VALUES ('Sue'), ('Jane'); 
    Query OK, 2 rows affected (0.00 sec) Records: 2?Duplicates: 0?Warnings: 0 

 

然后檢查chars表格看MySQL觸發(fā)器是否完成它該完成的任務(wù):

 

 

  1. mysql> SELECT * FROM chars; +-------+ 
    | count | +-------+ | 7| +-------+ 1 row in set (0.00 sec) 

 

如你所見,data表格中的INSERT命令激活觸發(fā)器,它計(jì)算插入記錄的字符數(shù),并將結(jié)果存儲(chǔ)在chars表格中。如果你往data表格中增加另外的記錄,chars.count值也會(huì)相應(yīng)增加。

觸發(fā)器應(yīng)用完畢后,可有DROP TRIGGER命令輕松刪除它。

 

 

 

  1. mysql> DROP TRIGGER t1; Query OK, 0 rows affected (0.00 sec) 

 

注意:理想情況下,你還需要一個(gè)倒轉(zhuǎn)觸發(fā)器,每當(dāng)一個(gè)記錄從源表格中刪除時(shí),它從字符總數(shù)中減去記錄的字符數(shù)。這很容易做到,你可以把它當(dāng)作練習(xí)來完成。提示:應(yīng)用BEFORE DELETE ON子句是其中一種方法。

自寫(已測(cè)試)

 

 

  1. mysql> create trigger t2 before delete on 
    data for each row update chars set 
    countcount=count-char_length(old.name); 
    Query OK, 0 rows affected (0.03 sec) 

 

現(xiàn)在,我想建立一個(gè)審計(jì)記錄來追蹤對(duì)這個(gè)表格所做的改變。這個(gè)記錄將反映表格的每項(xiàng)改變,并向用戶說明由誰做出改變以及改變的時(shí)間。我需要建立一個(gè)新表格來存儲(chǔ)這一信息(表格名:audit),如下所示。(列表C)

列表C

 

 

 

  1. mysql> CREATE TABLE audit (id INT(7), balance FLOAT, 
    user VARCHAR(50) NOT NULL, time TIMESTAMP NOT NULL); 
    Query OK, 0 rows affected (0.09 sec) 
    mysql
    > create table accounts(id int(7),label VARCHAR(45),balance float); 

 

接下來,我將在accounts表格中定義一個(gè)MySQL觸發(fā)器。(列表D)

列表D

 

 

 

  1. mysql> CREATE TRIGGER t3 AFTER UPDATE ON accounts 
    FOR EACH ROW INSERT INTO audit (id, balance, user, time) 
    VALUES (OLD.id, NEW.balance, CURRENT_USER(), NOW()); 
    Query OK, 0 rows affected (0.04 sec) 

 

如果你已經(jīng)走到這一步,就很容易理解。accounts表格每經(jīng)歷一次UPDATE,觸發(fā)器插入(INSERT)對(duì)應(yīng)記錄的id、新的余額、當(dāng)前時(shí)間和登錄audit表格的用戶的名稱。

實(shí)現(xiàn)中的例子:用觸發(fā)器審計(jì)記錄

既然你了解了觸發(fā)器的基本原理,讓我們來看一個(gè)稍稍復(fù)雜的例子。我們常用觸發(fā)器來建立一個(gè)自動(dòng)“審計(jì)記錄”,以記錄各種用戶對(duì)數(shù)據(jù)庫的更改。為了解審計(jì)記錄的實(shí)際應(yīng)用,請(qǐng)看下面的表格(表格名:accounts),它列出了一個(gè)用戶的三個(gè)銀行賬戶余額。(表A)

 

表A

 

 

 

  1. mysql> SELECT * FROM accounts; +----+------------+---------+ 
    | id | label| balance | +----+------------+---------+ 
    |1 | Savings #1 |500 | |2 | Current #1 |2000 | |3 | 
    Current #2 |3500 | +----+------------+---------+ 3 rows in set (0.00 sec) 

 

然后,檢查觸發(fā)器是否被激活:

 

 

  1. mysql> SHOW TRIGGERS ; *************************** 
    1. row *************************** ?Trigger: t1 ?Event: 
    UPDATE ?Table: accounts Statement: INSERT INTO audit (id, balance, user, time) 
    VALUES (OLD.id, NEW.balance, CURRENT_USER(), NOW()) Timing: AFTER ?Created: NULL Sql_mode: 1 row in set (0.01 sec) 

 

再來看***的結(jié)果(列表E):

列表E

 

 

 

  1. mysql> UPDATE accounts SET balance = 500 WHERE id = 
    1; Query OK, 1 row affected (0.00 sec) Rows matched: 
    1?Changed: 1?Warnings: 0 mysql
    > UPDATE accounts SET 
    balance = 900 WHERE id = 3; Query OK, 1 row affected 
    (0.01 sec) Rows matched: 1?Changed: 1?Warnings: 0 mysql
    > 
    UPDATE accounts SET 
    balance = 1900 WHERE id = 1; Query OK, 
    1 row affected (0.00 sec) Rows matched: 1?Changed: 1?Warnings: 0  

 

注意,對(duì)accounts表格所作的改變已被記錄到audit表格中,將來如果出現(xiàn)問題,我們可以方便地從中進(jìn)行恢復(fù)。

 

 

  1. mysql> SELECT * FROM audit; +------+---------+----------------+---------------------+ 
    | id| balance | user| time| +------+---------+----------------+---------------------+ 
    |1 |500 | root@localhost | 2006-04-22 12:52:15 | |3 |900 | root@localhost | 2006-04-22 12:53:15 
    | |1 |1900 | root@localhost | 2006-04-22 12:53:23 | +------+---------+----------------+---------------------+ 3 rows in set (0.00 sec)  

 

如上面的例子所示,MySQL觸發(fā)器是一個(gè)強(qiáng)大的新功能,它大大增強(qiáng)了RDBMS的自動(dòng)化程度。自己去試驗(yàn),練習(xí)吧!

【編輯推薦】

  1. MySQLunion 語法代碼演示
  2. 導(dǎo)致MySQL Alter Table函數(shù)信息泄露的原因
  3. MySQL alter 語句的實(shí)際操作
  4. MySQL查詢優(yōu)化的5個(gè)好用方法
  5. MySQL修改表字段的實(shí)際應(yīng)用代碼演示

 

 

 

責(zé)任編輯:佚名 來源: 互聯(lián)網(wǎng)
相關(guān)推薦

2010-05-18 15:58:39

MySQL觸發(fā)器

2010-05-04 09:44:12

Oracle Trig

2010-05-18 15:36:44

MySQL觸發(fā)器

2011-04-14 10:53:00

MySQLSQL觸發(fā)器

2010-10-12 10:10:55

mysql觸發(fā)器

2009-10-22 17:18:20

CLR觸發(fā)器

2010-10-12 10:04:15

MySQL觸發(fā)器

2010-05-31 18:06:07

MySQL 觸發(fā)器

2010-04-29 10:48:10

Oracle序列

2009-04-07 13:56:03

SQL Server觸發(fā)器實(shí)例

2010-10-11 14:52:43

Mysql觸發(fā)器

2021-07-30 10:33:57

MySQL觸發(fā)器數(shù)據(jù)

2011-05-20 14:06:25

Oracle觸發(fā)器

2010-10-12 10:24:58

mysql觸發(fā)器

2010-10-12 09:41:26

mysql觸發(fā)器

2010-10-12 10:38:29

mysql觸發(fā)器

2011-03-03 09:30:24

downmoonsql登錄觸發(fā)器

2010-09-01 16:40:00

SQL刪除觸發(fā)器

2010-05-26 17:57:44

MySQL 觸發(fā)器

2010-04-26 14:12:23

Oracle使用游標(biāo)觸
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)