亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費注冊 查看新帖 |

Chinaunix

  平臺 論壇 博客 文庫
最近訪問板塊 發(fā)新帖
查看: 1101 | 回復(fù): 0
打印 上一主題 下一主題

妙用觸發(fā)器有效的管理MySQL數(shù)據(jù)庫 [復(fù)制鏈接]

論壇徽章:
0
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報告]
發(fā)表于 2011-12-19 13:55 |只看該作者 |倒序瀏覽

在SQL中,名詞觸發(fā)器指“在數(shù)據(jù)庫中為響應(yīng)一個特殊表格中的某些事件而自動執(zhí)行的程序代碼!(Wikipedia)說得簡單一些,它是在一個特殊的數(shù)據(jù)庫事件,如INSERT或DELETE發(fā)生時,自動激活的一段代碼。觸發(fā)器可方便地用于日志記錄、對單個表格到其他鏈接式表格進行自動的“層疊式”更改、或保證對表格關(guān)系進行自動更新。當(dāng)一個新整數(shù)值增加到數(shù)據(jù)庫域中時,自動更新運行的總數(shù)的代碼段是一個觸發(fā)器。自動記錄對一個特殊數(shù)據(jù)庫表格所作更改的SQL命令塊也是一個觸發(fā)器實例。

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

一個簡單實例

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

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 count = count + CHAR_LENGTH(NEW.name);

Query OK, 0 rows affected (0.01 sec)

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

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

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)鍵字也值得注意。這個關(guān)鍵字表明觸發(fā)器應(yīng)考慮域的new值(也就是說,剛被插入到域中的值)。MySQL還支持相應(yīng)的OLD前綴,可用它來指域以前的值。

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

mysql> SHOW TRIGGERS\G

*************************** 1. row ***************************

?Trigger: t1

?Event: INSERT

?Table: data

Statement: UPDATE chars SET count = count + CHAR_LENGTH(NEW.name)

Timing: AFTER

?Created: NULL

ql_mode:

1 row in set (0.01 sec)

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

mysql> INSERT INTO data (name) VALUES ('Sue'), ('Jane');

Query OK, 2 rows affected (0.00 sec)

Records: 2?Duplicates: 0?Warnings: 0

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

mysql> SELECT * FROM chars;

+-------+

| count |

+-------+

| 7|

+-------+

1 row in set (0.00 sec)

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

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

mysql> DROP TRIGGER t1;

Query OK, 0 rows affected (0.00 sec)

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

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

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)

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

mysql> CREATE TRIGGER t1 AFTER UPDATEON 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)對應(yīng)記錄的id、新的余額、當(dāng)前時間和登錄audit表格的用戶的名稱。

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

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ā)器是否被激活:

mysql> SHOW TRIGGERS \G

*************************** 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é)果:

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

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

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)

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

您需要登錄后才可以回帖 登錄 | 注冊

本版積分規(guī)則 發(fā)表回復(fù)

  

北京盛拓優(yōu)訊信息技術(shù)有限公司. 版權(quán)所有 京ICP備16024965號-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報專區(qū)
中國互聯(lián)網(wǎng)協(xié)會會員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關(guān)心和支持過ChinaUnix的朋友們 轉(zhuǎn)載本站內(nèi)容請注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP