mysqltrigger實例的簡單介紹

本文目錄一覽:

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如何用觸發器實現新增時刪除最後一條數據

首先mysql 只支持3種觸發器

1 DELETE 2 INSERT 3 UPDATE

其他的MySQL語句不支持觸發器,所以你第二個需求不能用觸發器實現。

其次是 非常遺憾,MYSQL中觸發器中不能對本表進行 insert ,update ,delete 操作,以免遞歸循環觸發。所以你第一個需求不能在insert前刪除本表數據

對於update 能用set 進行操作替換,insert與delete只能藉助第二張表才能實現需要的目的。

在mysql中如何查看和修改觸發器的代碼?請問各位大師,小弟先謝謝了!!!!!!!!!

mysql中,觸發器只能查看,無法修改,如果要修改,只能刪除原有的觸發器,重新創建觸發器,以達到修改的目的。

工具:Navicat Premiu

步驟:

1、正確安裝Navicat Premiu,並確保連接到指定的數據庫。

2、以連接本地數據庫localhost中的badkano數據庫為例。

3、點擊軟件上方的查詢-新建查詢。

4、先執行SHOW TRIGGERS,查看數據庫中的觸發器。

5、如果要修改觸發器,需要刪除掉這個觸發器。執行語句為:

DROP TRIGGER t_afterdelete_on_tab1;

6、然後重新創建即可。

mysql trigger什麼時候用

mysql trigger 在insert,update,delete之前或之後候用

首先,我們需要確定自己的Mysql數據庫的版本,因為my sql數據庫是從5.0.2版本才開始支持觸發器的。

我推薦大家在電腦的dos命令界面中輸入 mysql –version,來獲取mysql的版本號,注意version的兩個橫線和之前的mysql是有一個空格的。

上一步獲取了我們的mysql版本號,這一不我們就開始建立觸發器了。我採用的以視圖加代碼的方式創建,我們在數據表中找到要執行刪除操作的表,然後右鍵設計表

這樣我們就打開了表的設計頁面,可以看到有一個觸發器選項卡,我們點擊“觸發器”

可以看到對應的選項,我們在名裡面添加我們需要新建的觸發器的名字,在觸發選項中選擇before或者after,然後在插入、更新、刪除三個選項中勾選一個。

這樣我們就建立了一個名為“datri”的觸發器,在刪除操作執行之後觸發

然後我們在下面的定義下面的框中輸入我們需要執行的操作。然後點擊sql預覽,可以看到整個觸發器的代碼

8

最後就是保存了,由於我們做的是觸發器,保存之後,在執行刪除操作時,這個觸發器才相當於 被執行。

Mysql trigger 簡單問題,請教大神

DELIMITER

//

CREATE

TRIGGER

tir_dep_insert

AFTER

INSERT

ON

empdep

FOR

EACH

ROW

BEGIN

UPDATE

empfo

SET

depid

=

new.depid,

depname

=

new.depnme

WHERE

id

=

new.id

;

END//

MySQL

存儲過程,

要先調用

DELIMITER

,

設定另外一種符號

作為

語句的

“終止符號”

因為

mysql

默認是以

分號

;

作為語句的終止符號了。

如果沒有定義的話,

那麼遇到的第一個

分號,

mysql

就認為語句執行結束了。

另外

沒見過

inserted

mysql 觸發器 怎麼使用 函數

語法如下:

CREATE TRIGGER trigger_name trigger_time trigger_event

ON tbl_name FOR EACH ROW trigger_stmt

觸發程序是與表有關的命名數據庫對象,當表上出現特定事件時,將激活該對象。

觸發程序與命名為tbl_name的表相關。tbl_name必須引用永久性表。不能將觸發程序與臨時表表或視圖關聯起來。

trigger_time是觸發程序的動作時間。它可以是BEFORE或AFTER,以指明觸發程序是在激活它的語句之前或之後觸發。

trigger_event指明了激活觸發程序的語句的類型。trigger_event可以是下述值之一:

· INSERT:將新行插入表時激活觸發程序,例如,通過INSERT、LOAD DATA和REPLACE語句

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/204442.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-07 12:17
下一篇 2024-12-07 12:17

相關推薦

  • Python生成隨機數的應用和實例

    本文將向您介紹如何使用Python生成50個60到100之間的隨機數,並將列舉使用隨機數的幾個實際應用場景。 一、生成隨機數的代碼示例 import random # 生成50個6…

    編程 2025-04-29
  • Python簡單數學計算

    本文將從多個方面介紹Python的簡單數學計算,包括基礎運算符、函數、庫以及實際應用場景。 一、基礎運算符 Python提供了基礎的算術運算符,包括加(+)、減(-)、乘(*)、除…

    編程 2025-04-29
  • Python滿天星代碼:讓編程變得更加簡單

    本文將從多個方面詳細闡述Python滿天星代碼,為大家介紹它的優點以及如何在編程中使用。無論是剛剛接觸編程還是資深程序員,都能從中獲得一定的收穫。 一、簡介 Python滿天星代碼…

    編程 2025-04-29
  • Python海龜代碼簡單畫圖

    本文將介紹如何使用Python的海龜庫進行簡單畫圖,並提供相關示例代碼。 一、基礎用法 使用Python的海龜庫,我們可以控制一個小海龜在窗口中移動,並利用它的“畫筆”在窗口中繪製…

    編程 2025-04-29
  • Python櫻花樹代碼簡單

    本文將對Python櫻花樹代碼進行詳細的闡述和講解,幫助讀者更好地理解該代碼的實現方法。 一、簡介 櫻花樹是一種圖形效果,它的實現方法比較簡單。Python中可以通過turtle這…

    編程 2025-04-28
  • Python大神作品:讓編程變得更加簡單

    Python作為一種高級的解釋性編程語言,一直被廣泛地運用於各個領域,從Web開發、遊戲開發到人工智能,Python都扮演着重要的角色。Python的代碼簡潔明了,易於閱讀和維護,…

    編程 2025-04-28
  • 如何在dolphinscheduler中運行chunjun任務實例

    本文將從多個方面對dolphinscheduler運行chunjun任務實例進行詳細的闡述,包括準備工作、chunjun任務配置、運行結果等方面。 一、準備工作 在運行chunju…

    編程 2025-04-28
  • 用Python實現簡單爬蟲程序

    在當今時代,互聯網上的信息量是爆炸式增長的,其中很多信息可以被利用。對於數據分析、數據挖掘或者其他一些需要大量數據的任務,我們可以使用爬蟲技術從各個網站獲取需要的信息。而Pytho…

    編程 2025-04-28
  • 如何製作一個簡單的換裝遊戲

    本文將從以下幾個方面,為大家介紹如何製作一個簡單的換裝遊戲: 1. 遊戲需求和界面設計 2. 使用HTML、CSS和JavaScript開發遊戲 3. 實現遊戲的基本功能:拖拽交互…

    編程 2025-04-27
  • Guava Limiter——限流器的簡單易用

    本文將從多個維度對Guava Limiter進行詳細闡述,介紹其定義、使用方法、工作原理和案例應用等方面,並給出完整的代碼示例,希望能夠幫助讀者更好地了解和使用該庫。 一、定義 G…

    編程 2025-04-27

發表回復

登錄後才能評論