日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

MySQL触发器的使用

發布時間:2025/3/20 数据库 46 豆豆
生活随笔 收集整理的這篇文章主要介紹了 MySQL触发器的使用 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

概述:

? 當具體的表發生特定的數據庫事件時,觸發器執行對應的SQL命令。


語法:

創建觸發器的一般命令如下:

CREATE [temp|temporary] trigger name

[before|after] [insert|delete|update|update of columns] ON table

action


觸發器的使用:

創建:

mysql> CREATE TRIGGER stu_trigger AFTER INSERT
? ? -> ON students
? ? -> FOR EACH ROW
? ? -> INSERT INTO info(stu_id, info) values (new.id, '');
Query OK, 0 rows affected (0.07 sec)


觸發事件:

mysql> INSERT INTO students(id, name, age) values (4, 'Zeus', 56400);
Query OK, 1 row affected (0.00 sec)


驗證students表結果:

mysql> SELECT * FROM students;
+------+----------------+--------+
| id ? | name ? ? ? ? ? | age ? ?|
+------+----------------+--------+
| ? ?1 | bumblebee ? ? ?| ? ?800 |
| ? ?2 | king of monkey | ?10000 |
| ? ?3 | Medusa ? ? ? ? | 100000 |
| ? ?4 | Zeus ? ? ? ? ? | ?56400 |
+------+----------------+--------+
4 rows in set (0.00 sec)


驗證info表結果:

mysql> SELECT * FROM info;
+----+--------+---------------------------------+
| id | stu_id | info ? ? ? ? ? ? ? ? ? ? ? ? ? ?|
+----+--------+---------------------------------+
| ?1 | ? ? ?1 | A member of the deformed steel. |
| ?2 | ? ? ?2 | Hero in Chinese Mythology. ? ? ?|
| ?3 | ? ? ?3 | In Greek mythology the Gorgon. ?|
| ?5 | ? ? ?4 | ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? |
+----+--------+---------------------------------+
4 rows in set (0.00 sec)

注:這里的新id為5而不為4的原因,是因為之前對info表作了刪除操作導致。


查看觸發器的信息:

mysql> SELECT * FROM information_schema.triggers;
+----------------+--------------+--------------------+---------------------+
| TRIGGER_SCHEMA | TRIGGER_NAME | EVENT_MANIPULATION | EVENT_OBJECT_SCHEMA |
+----------------+--------------+--------------------+---------------------+
| student ? ? ? ?| stu_trigger ?| INSERT ? ? ? ? ? ? | student ? ? ? ? ? ? |
+----------------+--------------+--------------------+---------------------+


+--------------------+----------------------------------------------------+
| EVENT_OBJECT_TABLE | ACTION_STATEMENT ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? |
+--------------------+----------------------------------------------------+
| students ? ? ? ? ? | INSERT INTO info(stu_id, info) values (new.id, '') |
+--------------------+----------------------------------------------------+

1 row in set (0.19 sec)

注:上面的打印信息是刪減版的,完整的信息,可以自行在環境中查看。


刪除觸發器:

mysql> DROP TRIGGER stu_trigger;
Query OK, 0 rows affected (0.01 sec)

驗證刪除結果:

mysql> SELECT * FROM information_schema.triggers;
Empty set (0.01 sec)

說明刪除成功了



總結

以上是生活随笔為你收集整理的MySQL触发器的使用的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。