您的位置:

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语句

mysqltrigger实例的简单介绍

2022-11-15
python使用笔记23的简单介绍

2022-11-10
数据库的笔记mysql,数据库管理系统笔记

2022-11-24
javascript入门笔记1的简单介绍

2022-11-18
c到c语言笔记的简单介绍

2022-11-24
重拾python笔记三的简单介绍

2022-11-13
mysql数据库完整笔记(mysql数据库数据)

2022-11-13
Markdown笔记的全方位介绍

2023-05-18
mysql数据库开发笔记(mysql数据库应用案例教程电子版

2022-11-14
win7iisphp的简单介绍

2022-11-22
python使用笔记006的简单介绍

2022-11-15
phpmysqlzend的简单介绍

2023-01-04
python学习之笔记(python的笔记)

2022-11-10
jstorm实例的简单介绍

本文目录一览: 1、Storm中进程,线程,任务和实例的关系 2、storm基本概念 3、请教,icestorm的实例实现,出现了问题 4、如何在Windows下搭建Storm Storm中进程,线程

2023-12-08
mysql样例代码的简单介绍

2022-11-22
java基础知识学习笔记一,Java基础笔记

2022-11-21
websocketredisnodejs的简单介绍

本文目录一览: 1、node.js中如何配置redis与连接池? 2、Nodejs 连接 Redis数据库实例 3、nodejs怎么引入redis 4、如何在Nodejs中使用缓存 5、nodejs服

2023-12-08
python笔记二(2python)

2022-11-11
我的python笔记06(Python)

2022-11-14
chinacxjs.org的简单介绍

本文目录一览: 1、哪里有免费的100M的虚拟空间提供啊 2、如何投稿? 3、有没有小学生作文投稿网站? 哪里有免费的100M的虚拟空间提供啊 -- 免费空间列表 免费空间列表如下: 一、一般免费空间

2023-12-08