mysql触发器语句
时间: 2023-06-28 14:07:32 浏览: 150
MySQL触发器语句可以通过以下语法来创建:
```mysql
CREATE TRIGGER trigger_name
{BEFORE | AFTER} {INSERT | UPDATE | DELETE}
ON table_name
FOR EACH ROW
trigger_body
```
其中,`trigger_name` 为触发器名称,`table_name` 为触发器所在的表名,`trigger_body` 为触发器的执行体。
触发器可以在 INSERT、UPDATE 或 DELETE 操作执行前或执行后自动执行一些特定的操作。对于一个给定的表,可以有多个触发器,每个触发器对应一种操作类型(INSERT、UPDATE 或 DELETE)。
例如,下面的代码展示了一个在 `orders` 表上创建的触发器,该触发器在每次插入新行时自动更新 `order_count` 列的值:
```mysql
CREATE TRIGGER update_order_count
AFTER INSERT ON orders
FOR EACH ROW
UPDATE order_summary SET order_count = order_count + 1 WHERE user_id = NEW.user_id;
```
其中,`NEW` 表示正在执行 INSERT 操作的当前行的引用。在这个例子中,我们使用了 `NEW.user_id` 来获取插入的用户 ID,并将其用于更新 `order_summary` 表中的 `order_count` 列。
相关问题
MySQL 创建触发器语句
在MySQL中,创建触发器是一种预定义事件的机制,当特定的表操作(比如INSERT、UPDATE或DELETE)发生时,它们会自动执行事先定义好的SQL语句。触发器的基本语法如下:
```sql
CREATE TRIGGER trigger_name
AFTER|BEFORE event_type ON table_name
FOR EACH ROW
BEGIN
-- 触发器执行的SQL语句块
INSERT INTO log_table (event, old_data, new_data) VALUES ('ACTION', OLD.column, NEW.column);
END;
```
这里的关键部分包括:
- `trigger_name`: 你要为触发器起的名字。
- `AFTER|BEFORE`: 指定事件何时触发,`AFTER`在操作完成后执行,`BEFORE`则在操作开始前执行。
- `event_type`: 可能是`INSERT`, `UPDATE`, 或`DELETE`.
- `table_name`: 触发器关联的操作数据表名。
- `FOR EACH ROW`: 指示每次操作每行都会触发一次这个触发器。
- `BEGIN...END`: 包含要执行的SQL语句。
例如,创建一个在插入新记录时更新另一个计数字段的简单触发器:
```sql
CREATE TRIGGER increment_count
AFTER INSERT ON orders
FOR EACH ROW
BEGIN
UPDATE products SET stock = stock - 1 WHERE product_id = NEW.product_id;
END;
```
mysql触发器多语句
MySQL触发器是一种特殊的存储过程,它会在特定的数据库操作(如INSERT、UPDATE或DELETE)发生时自动执行预先定义好的SQL语句序列。触发器可以包含一条或多条SQL语句,用于执行数据验证、业务规则检查、数据审计或历史记录更新等功能。
创建一个多语句触发器的基本语法是这样的:
```sql
CREATE TRIGGER trigger_name
AFTER|BEFORE event_type ON table_name
FOR EACH ROW
BEGIN
-- 多条SQL语句,每个语句之间用分号隔开
SQL statement 1;
SQL statement 2;
...
END;
```
其中:
- `trigger_name`:是你给触发器起的名字。
- `event_type`:可以是`AFTER`表示操作完成后触发,或是`BEFORE`表示操作开始前触发。
- `table_name`:触发器关联的表名。
- `FOR EACH ROW`:表明每行数据操作都会单独触发一次。
例如,如果你想在一个表的插入后更新另一个表,并且如果插入失败则回滚,你可以这样做:
```sql
CREATE TRIGGER after_insert_trigger
AFTER INSERT ON my_table
FOR EACH ROW
BEGIN
UPDATE other_table SET column = NEW.column_value WHERE condition;
IF SQLSTATE <> '00000' THEN
ROLLBACK;
END IF;
END;
```
阅读全文