db-tutorial/codes/mysql/触发器示例.sql

71 lines
2.2 KiB
MySQL
Raw Normal View History

2020-02-29 22:32:57 +08:00
/**
* Mysql TRIGGER使
2023-10-26 07:02:27 +08:00
* @author <a href="mailto:forbreak@163.com">Zhang Peng</a>
2020-02-29 22:32:57 +08:00
* @date 2018/5/2
*/
-- --------------------------------------------------------------------------------------
-- Mysql 基本 DDL 语句示例
2023-10-26 07:02:27 +08:00
-- @author <a href="mailto:forbreak@163.com">Zhang Peng</a>
2020-02-29 22:32:57 +08:00
-- @date 2018/4/28
-- ----------------------------------------------------------------------------------------
-- --------------------------------------------------------------------- 数据库定义
#############################################################
# 运行本例的预置操作
#############################################################
-- 新建数据表 user
DROP TABLE IF EXISTS user;
CREATE TABLE user (
id INT(10) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT 'Id',
username VARCHAR(64) NOT NULL DEFAULT 'default' COMMENT '用户名',
password VARCHAR(64) NOT NULL DEFAULT 'default' COMMENT '密码',
email VARCHAR(64) NOT NULL DEFAULT 'default' COMMENT '邮箱',
PRIMARY KEY (id)
) COMMENT ='用户表';
-- 新建数据表 user_history
DROP TABLE IF EXISTS user_history;
CREATE TABLE user_history (
id INT(10) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT 'ID',
user_id INT(10) UNSIGNED NOT NULL DEFAULT 0 COMMENT '用户ID',
operate_type VARCHAR(64) NOT NULL DEFAULT 'default' COMMENT '操作类型',
operate_time VARCHAR(64) NOT NULL DEFAULT 'default' COMMENT '操作时间',
PRIMARY KEY (id)
) COMMENT ='用户记录表';
#############################################################
# 创建触发器
#############################################################
-- 删除触发器
DROP TRIGGER IF EXISTS trigger_insert_user;
-- 创建触发器
DELIMITER $
CREATE TRIGGER trigger_insert_user
AFTER INSERT
ON user
FOR EACH ROW
BEGIN
INSERT INTO user_history(user_id, operate_type, operate_time)
VALUES (NEW.id, 'add a user', now());
END $
DELIMITER ;
-- 查看触发器
SHOW TRIGGERS;
#############################################################
# 测试
#############################################################
INSERT INTO user(username, password, email)
VALUES ('admin', 'admin', 'xxxx@163.com');
SELECT *
FROM user_history;