當前位置:首頁 » 數據倉庫 » mysql跨資料庫觸發器
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

mysql跨資料庫觸發器

發布時間: 2022-10-19 12:13:02

㈠ 怎樣使用Mysql新建觸發器

使用Mysql新建觸發器的方法:
1、首先,需要確定自己的Mysql資料庫的版本,因為my sql資料庫是從5.0.2版本才開始支持觸發器的。
2、在電腦的dos命令界面中輸入 mysql --version,來獲取mysql的版本號,注意version的兩個橫線和之前的mysql是有一個空格的。
3、上一步獲取了mysql版本號,就開始建立觸發器。採用以視圖加代碼的方式創建,在數據表中找到要執行刪除操作的表,然後右鍵設計表
4、這樣就打開了表的設計頁面,可以看到有一個觸發器選項卡,點擊「觸發器」
5、可以看到對應的選項,在名裡面添加需要新建的觸發器的名字,在觸發選項中選擇before或者after,然後在插入、更新、刪除三個選項中勾選一個。
6、這樣們就建立了一個名為「datri」的觸發器,在刪除操作執行之後觸發
7、然後在下面的定義下面的框中輸入需要執行的操作。然後點擊sql預覽,可以看到整個觸發器的代碼
8、最後就是保存了,由於做的是觸發器,保存之後,在執行刪除操作時,這個觸發器才相當於被執行。

㈡ 資料庫中的「觸發器」是什麼意思

在SQL中,名詞觸發器指「在資料庫中為響應一個特殊表格中的某些事件而自動執行的程序代碼。」(Wikipedia)說得簡單一些,它是在一個特殊的資料庫事件,如INSERT或DELETE發生時,自動激活的一段代碼。觸發器可方便地用於日誌記錄、對單個表格到其他鏈接式表格進行自動的「層疊式」更改、或保證對表格關系進行自動更新。當一個新整數值增加到資料庫域中時,自動更新運行的總數的代碼段是一個觸發器。自動記錄對一個特殊資料庫表格所作更改的SQL命令塊也是一個觸發器實例

㈢ 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怎麼實現跨庫觸發器

CREATE TRIGGER t_afterinsert_on_tab1
AFTER INSERT ON tab1
FOR EACH ROW
BEGIN
insert into <span style="color: #FF0000;">db2</span>.tab2(tab2_id) values(new.tab1_id);
END;

㈤ mysql觸發器可以跨伺服器操作嗎

1 直接的話,試試federated能不能滿足。
在1伺服器上開啟federated引擎支持,創建一個federated引擎表bb2表connection到2伺服器的b表
在aa的觸發器中更新bb2表。
不過federated有較多的限制,也缺乏錯誤檢測,整個過程的實現需要考慮周全。
2 間接的話,只能把aa表數據同步過去,在2伺服器中使用修改後的aa觸發器更新bb表。

㈥ 在mysql中的兩個不同的資料庫之間建立觸發器連接

若想利用此方法達到反向同步則可能出現問題,比如想在parkfee資料庫有新數據插入時讓當前資料庫也同時插入一條記錄,建立一個觸發器,則形成了一個循環觸發,當插入數據時會報大於最大遞歸次數錯。因此因避免這樣的觸發循環,若要達到類似效果還須想別的方法。(待續)
補充:
若兩個庫處於不同的資料庫伺服器則應先進行以下操作:
在 server1 上創建連接伺服器,以便在 server1 中操作 server2,實現同步
exec sp_addlinkedserver 'server2','','SQLOLEDB','server2的資料庫實例名或ip'
exec sp_addlinkedsrvlogin 'server2','false',null,'用戶名','密碼'
go

㈦ mysql觸發器的作用

資料庫觸發器有下面的作用:
1.安全性。能夠基於資料庫的值使用戶具有操作資料庫的某種權利。
  # 能夠基於時間限制用戶的操作,比如不同意下班後和節假日改動資料庫數據。
2.審計。能夠跟蹤用戶對資料庫的操作。   
  # 審計用戶操作資料庫的語句。
  # 把用戶對資料庫的更新寫入審計表。
3.實現復雜的數據完整性規則
  # 實現非標準的數據完整性檢查和約束。觸發器可產生比規則更為復雜的限制。與規則不同,觸發器能夠引用列或資料庫對象。比如,觸發器可回退不論什麼企圖吃進超過自己保證金的期貨。
  # 提供可變的預設值。
4.實現復雜的非標準的資料庫相關完整性規則。觸發器能夠對資料庫中相關的表進行連環更新。比如,在auths表author_code列上的刪除觸發器可導致對應刪除在其他表中的與之匹配的行。
  # 在改動或刪除時級聯改動或刪除其他表中的與之匹配的行。
  # 在改動或刪除時把其他表中的與之匹配的行設成NULL值。
  # 在改動或刪除時把其他表中的與之匹配的行級聯設成預設值。
  # 觸發器可以拒絕或回退那些破壞相關完整性的變化,取消試圖進行數據更新的事務。當插入一個與其主健不匹配的外部鍵時,這樣的觸發器會起作用。比如,可以在books.author_code 列上生成一個插入觸發器,假設新值與auths.author_code列中的某值不匹配時,插入被回退。
5.同步實時地復製表中的數據。
6.自己主動計算數據值,假設數據的值達到了一定的要求,則進行特定的處理