mysql触发器
2014-03-03 19:39
399 查看
触发器,一般不要单独调用,主要发生响应的事件mysql会自动调用。
语法:
create trigger 触发器名称 指定执行的时间 on 指定在什么表上执行操作 影响的行数 需要执行的任务或者业务
mysql> desc data
-> ;
+-------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| name | varchar(20) | YES | | NULL | |
+-------+-------------+------+-----+---------+-------+
1 row in set (0.01 sec)
mysql> desc chars;
+-------+---------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+---------+------+-----+---------+-------+
| count | int(10) | YES | | NULL | |
+-------+---------+------+-----+---------+-------+
1 row in set (0.01 sec)
mysql> insert into chars values(0);
Query OK, 1 row affected (0.05 sec)
mysql> create trigger tr1 after insert on data
-> for each row update chars set count=count+char_length(new.name);
Query OK, 0 rows affected (0.20 sec)
mysql> select * from chars;
+-------+
| count |
+-------+
| 0 |
+-------+
1 row in set (0.00 sec)
mysql> insert into data values("jack");
Query OK, 1 row affected (0.09 sec)
mysql> select * from chars;
+-------+
| count |
+-------+
| 4 |
+-------+
1 row in set (0.00 sec)
mysql> insert into data values("cainiao");
Query OK, 1 row affected (0.05 sec)
mysql> select * from chars;
+-------+
| count |
+-------+
| 11 |
+-------+
1 row in set (0.00 sec)
语法:
create trigger 触发器名称 指定执行的时间 on 指定在什么表上执行操作 影响的行数 需要执行的任务或者业务
mysql> desc data
-> ;
+-------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| name | varchar(20) | YES | | NULL | |
+-------+-------------+------+-----+---------+-------+
1 row in set (0.01 sec)
mysql> desc chars;
+-------+---------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+---------+------+-----+---------+-------+
| count | int(10) | YES | | NULL | |
+-------+---------+------+-----+---------+-------+
1 row in set (0.01 sec)
mysql> insert into chars values(0);
Query OK, 1 row affected (0.05 sec)
mysql> create trigger tr1 after insert on data
-> for each row update chars set count=count+char_length(new.name);
Query OK, 0 rows affected (0.20 sec)
mysql> select * from chars;
+-------+
| count |
+-------+
| 0 |
+-------+
1 row in set (0.00 sec)
mysql> insert into data values("jack");
Query OK, 1 row affected (0.09 sec)
mysql> select * from chars;
+-------+
| count |
+-------+
| 4 |
+-------+
1 row in set (0.00 sec)
mysql> insert into data values("cainiao");
Query OK, 1 row affected (0.05 sec)
mysql> select * from chars;
+-------+
| count |
+-------+
| 11 |
+-------+
1 row in set (0.00 sec)
相关文章推荐
- mysql查看所有存储过程,函数,视图,触发器,表
- mySQL查看存储过程、函数、视图、触发器
- MySQL 与 SQL 的触发器的不同写法
- MySQL 触发器、存储过程、游标
- 错误的触发器和正确的存储过程--mysql
- 9,mysql触发器
- mysql 触发器
- MySQL触发器、存储过程、自定义函数、视图 常用SQL
- Mysql触发器
- mysql之事务、触发器
- Mysql触发器
- mysql里面的触发器管理
- mysql夸库触发器
- mysql触发器不支持动态sql
- 积分触发器 mysql 触发器的使用
- mysql触发器的实例
- mysql——触发器
- 列举mysql的所有触发器以及删除触发器
- mysql触发器
- mysql触发器