本文目錄一覽:
如何利用MySQL數據庫在insert前觸發觸發器
第一步,在數據庫student里創建數據庫表building,創建語句為:
create table building(
id int(2),
bname varchar(30)
);
如下圖所示:
2
第二步,查看創建的數據庫表building的表結構,查看語句為:
desc building;
如下圖所示:
3
第三步,創建另外一張表building_information,創建語句為:
create table building_information(
id int(2),
bname varchar(30)
);
如下圖所示:
4
第四步,查看數據庫表building_information表結構,查看語句:
desc building_information;
如下圖所示:
5
第五步,創建觸發器build_trigger,創建語句為:
delimiter $$
create trigger build_trigger
before insert on building for each row begin
insert into building_information values (‘1′,’building’);
end;
$$
如下圖所示:
6
第六步,向數據庫表building插入一條記錄,這時已經觸發了觸發器,相應的building_information表裡也插入一條記錄,如下圖所示:
END
注意事項
區別觸發器的觸發時間和觸發事件
注意創建觸發器時需要用到delimiter
連鎖藥店mysql觸發器怎麼寫
語法說明如下。
1) 觸發器名
觸發器的名稱,觸發器在當前數據庫中必須具有唯一的名稱。如果要在某個特定數據庫中創建,名稱前面應該加上數據庫的名稱。
2) INSERT | UPDATE | DELETE
觸發事件,用於指定激活觸發器的語句的種類。
注意:三種觸發器的執行時間如下。INSERT:將新行插入表時激活觸發器。例如,INSERT 的 BEFORE 觸發器不僅能被 MySQL 的 INSERT 語句激活,也能被 LOAD DATA 語句激活。DELETE: 從表中刪除某一行數據時激活觸發器,例如 DELETE 和 REPLACE 語句。UPDATE:更改表中某一行數據時激活觸發器,例如 UPDATE 語句。
3) BEFORE | AFTER
BEFORE 和 AFTER,觸發器被觸發的時刻,表示觸發器是在激活它的語句之前或之後觸發。若希望驗證新數據是否滿足條件,則使用 BEFORE 選項;若希望在激活觸發器的語句執行之後完成幾個或更多的改變,則通常使用 AFTER 選項。
4) 表名
與觸發器相關聯的表名,此表必須是永久性表,不能將觸發器與臨時表或視圖關聯起來。在該表上觸發事件發生時才會激活觸發器。同一個表不能擁有兩個具有相同觸發時刻和事件的觸發器。例如,對於一張數據表,不能同時有兩個 BEFORE UPDATE 觸發器,但可以有一個 BEFORE UPDATE 觸發器和一個 BEFORE INSERT 觸發器,或一個 BEFORE UPDATE 觸發器和一個 AFTER UPDATE 觸發器。
5) 觸發器主體
觸發器動作主體,包含觸發器激活時將要執行的 MySQL 語句。如果要執行多個語句,可使用 BEGIN…END 複合語句結構。
mysql數據庫觸發器,怎麼做滿足條件觸發
建立兩個單域的表格。一個表格中為姓名列表(表格名:data)。
另一個表格中是所插入字符的字符數(表格名:chars)。在data表格中定義一個觸發器。
每次在其中插入一個新姓名時,chars表格中運行的總數就會根據新插入記錄的字符數目進行自動更新。
(見列表A)
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)
列表A
理解上面代碼的關鍵在於CREATE TRIGGER命令,被用來定義一個新觸發器。這個命令建立一個新觸發器,假定的名稱為t1,每次有一個新記錄插入到data表格中時,t1就被激活。
在這個觸發器中有兩個重要的子句:
AFTER INSERT子句表明觸發器在新記錄插入data表格後激活。
UPDATE chars SET count = count + CHAR_LENGTH(NEW.name)子句表示觸發器激活後執行的SQL命令。在本例中,該命令表明用新插入的data.name域的字符數來更新 chars.count欄。這一信息可通過內置的MySQL函數CHAR_LENGTH()獲得。
放在源表格域名前面的NEW關鍵字也值得注意。這個關鍵字表明觸發器應考慮域的new值(也就是說,剛被插入到域中的值)。MySQL還支持相應的OLD前綴,可用它來指域以前的值。
可以通過調用SHOW TRIGGER命令來檢查觸發器是否被激活,如列表B所示。
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)
列表B
激活觸發器後,開始對它進行測試。試着在data表格中插入幾個記錄:
mysql INSERT INTO data (name) VALUES (‘Sue’), (‘Jane’);
Query OK, 2 rows affected (0.00 sec)
Records: 2?Duplicates: 0?Warnings: 0
然後檢查chars表格看觸發器是否完成它該完成的任務:
mysql SELECT * FROM chars;
+——-+
| count |
+——-+
| 7|
+——-+
1 row in set (0.00 sec)
data表格中的INSERT命令激活觸發器,計算插入記錄的字符數,並將結果存儲在chars表格中。如果往data表格中增加另外的記錄,chars.count值也會相應增加。
觸發器應用完畢後,可有DROP TRIGGER命令輕鬆刪除它。
mysql DROP TRIGGER t1;
Query OK, 0 rows affected (0.00 sec)
注意:理想情況下,你還需要一個倒轉觸發器,每當一個記錄從源表格中刪除時,它從字符總數中減去記錄的字符數。這很容易做到,你可以把它當作練習來完成。提示:應用BEFORE DELETE ON子句是其中一種方法。
現在,要建立一個審計記錄來追蹤對這個表格所做的改變。這個記錄將反映表格的每項改變,並向用戶說明由誰做出改變以及改變的時間。需要建立一個新表格來存儲這一信息(表格名:audit),如下所示。(列表C)
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)
列表C
接下來,我將在accounts表格中定義一個觸發器。(列表D)
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)
列表D
要是已經走到這一步,就很容易理解。accounts表格每經歷一次UPDATE,觸發器插入(INSERT)對應記錄的id、新的餘額、當前時間和登錄audit表格的用戶的名稱。
實現中的例子:用觸發器審計記錄
既然了觸發器的基本原理,來看一個稍稍複雜的例子。常用觸發器來建立一個自動「審計記錄」,以記錄各種用戶對數據庫的更改。為了解審計記錄的實際應用,請看下面的表格(表格名:accounts),它列出了一個用戶的三個銀行賬戶餘額。(表A)
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)
表A
然後,檢查觸發器是否被激活:
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)
再來看最後的結果(列表E):
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
列表E
注意,對accounts表格所作的改變已被記錄到audit表格中,將來如果出現問題,可以方便地從中進行恢復。
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中的兩個不同的數據庫之間建立觸發器連接?
若想利用此方法達到反向同步則可能出現問題,比如想在parkfee數據庫有新數據插入時讓當前數據庫也同時插入一條記錄,建立一個觸發器,則形成了一個循環觸發,當插入數據時會報大於最大遞歸次數錯。因此因避免這樣的觸發循環,若要達到類似效果還須想別的方法。(待續)
補充:
若兩個庫處於不同的數據庫服務器則應先進行以下操作:
在 server1 上創建連接服務器,以便在 server1 中操作 server2,實現同步
exec sp_addlinkedserver ‘server2′,”,’SQLOLEDB’,’server2的數據庫實例名或ip’
exec sp_addlinkedsrvlogin ‘server2′,’false’,null,’用戶名’,’密碼’
go
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/300368.html