当前位置:   article > 正文

MySQL——触发器(trigger)基本结构

MySQL——触发器(trigger)基本结构


1、修改分隔符符号

delimiter $$

$$可以修改

2、创建触发器函数名称

create trigger 函数名 

3、什么样在操作触发,操作哪个表

after :……之后触发 

before :……之后触发 

insert :……之后触发 

update :……之后触发 

delete :……之后触发 


on 表名

实例

after insert on user

4、for each row 声明每次触发都被执行

5、 开始触发器代码

begin

6、 触发器触发后执行代码块

7、 结束触发器

end ;

8、 修改分隔符

$$

delimiter ; 

DDL

  1. CREATE TABLE user (
  2. user_id INT AUTO_INCREMENT PRIMARY KEY,
  3. username VARCHAR(50) NOT NULL UNIQUE,
  4. password VARCHAR(255) NOT NULL,
  5. email VARCHAR(100) UNIQUE,
  6. phone VARCHAR(20) UNIQUE,
  7. created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
  8. );
  9. CREATE TABLE user_wallet (
  10. wallet_id INT AUTO_INCREMENT PRIMARY KEY,
  11. user_id INT NOT NULL,
  12. balance DECIMAL(10, 2) NOT NULL DEFAULT 0.00,
  13. created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  14. FOREIGN KEY (user_id) REFERENCES user(user_id) ON DELETE CASCADE
  15. );
  16. CREATE TABLE user_wallet_log (
  17. log_id INT AUTO_INCREMENT PRIMARY KEY,
  18. user_id INT NOT NULL,
  19. transaction_type VARCHAR(50) NOT NULL,
  20. amount DECIMAL(10, 2) NOT NULL,
  21. transaction_time TIMESTAMP NOT NULL,
  22. FOREIGN KEY (user_id) REFERENCES user(user_id) ON DELETE CASCADE
  23. );
  24. CREATE TABLE product_type (
  25. type_id INT AUTO_INCREMENT PRIMARY KEY,
  26. type_name VARCHAR(100) NOT NULL,
  27. parent_id INT NULL,
  28. description TEXT,
  29. created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
  30. );
  31. CREATE TABLE product (
  32. product_id INT AUTO_INCREMENT PRIMARY KEY,
  33. product_name VARCHAR(255) NOT NULL,
  34. price DECIMAL(10, 2) NOT NULL DEFAULT 0.00,
  35. stock INT NOT NULL DEFAULT 0,
  36. type_id INT NOT NULL,
  37. created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  38. FOREIGN KEY (type_id) REFERENCES product_type(type_id) ON DELETE RESTRICT
  39. );
  40. CREATE TABLE `order` (
  41. `order_id` INT AUTO_INCREMENT PRIMARY KEY,
  42. `user_id` INT NOT NULL,
  43. `order_status` VARCHAR(50) NOT NULL DEFAULT '待支付',
  44. `order_time` TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  45. `payment_status` VARCHAR(50) NOT NULL DEFAULT '未支付',
  46. `payment_time` TIMESTAMP NULL,
  47. `total_price` DECIMAL(10, 2) NOT NULL DEFAULT 0.00,
  48. FOREIGN KEY (`user_id`) REFERENCES `user`(`user_id`) ON DELETE RESTRICT
  49. );
  50. CREATE TABLE order_info (
  51. order_info_id INT AUTO_INCREMENT PRIMARY KEY,
  52. order_id INT NOT NULL,
  53. product_id INT NOT NULL,
  54. quantity INT NOT NULL,
  55. unit_price DECIMAL(10, 2) NOT NULL,
  56. FOREIGN KEY (order_id) REFERENCES `order`(order_id) ON DELETE CASCADE,
  57. FOREIGN KEY (product_id) REFERENCES product(product_id) ON DELETE RESTRICT
  58. );

DML

user相关

  1. -- 插入10条用户数据
  2. INSERT INTO `user` VALUES ('1', '王语嫣', 'password1', 'user1@example.com', '13800000001', '2024-06-06 22:07:39');
  3. INSERT INTO `user` VALUES ('2', '小龙女', 'password2', 'user2@example.com', '13800000002', '2024-06-09 22:07:39');
  4. INSERT INTO `user` VALUES ('3', '赵灵儿', 'password3', 'user3@example.com', '13800000003', '2024-06-09 22:07:39');
  5. INSERT INTO `user` VALUES ('4', '杨过', 'password4', 'user4@example.com', '13800000004', '2024-05-31 22:07:39');
  6. INSERT INTO `user` VALUES ('5', '向问天', 'password5', 'user5@example.com', '13800000005', '2024-06-04 22:07:39');
  7. INSERT INTO `user` VALUES ('6', '杨潇', 'password6', 'user6@example.com', '13800000006', '2024-06-01 22:07:39');
  8. INSERT INTO `user` VALUES ('7', '郭靖', 'password7', 'user7@example.com', '13800000007', '2024-06-01 22:07:39');
  9. INSERT INTO `user` VALUES ('8', '黄蓉', 'password8', 'user8@example.com', '13800000008', '2024-06-04 22:07:39');
  10. INSERT INTO `user` VALUES ('9', '程英', 'password9', 'user9@example.com', '13800000009', '2024-06-08 22:07:39');
  11. INSERT INTO `user` VALUES ('10', '郭襄', 'password10', 'user10@example.com', '13800000010', '2024-06-08 22:07:39');
  12. -- 插入10条用户钱包数据,与user表对应
  13. INSERT INTO `user_wallet` VALUES ('1', '1', '422.00', '2024-06-08 22:07:42');
  14. INSERT INTO `user_wallet` VALUES ('2', '2', '897.00', '2024-06-04 22:07:42');
  15. INSERT INTO `user_wallet` VALUES ('3', '3', '354.00', '2024-06-03 22:07:42');
  16. INSERT INTO `user_wallet` VALUES ('4', '4', '758.00', '2024-06-07 22:07:42');
  17. INSERT INTO `user_wallet` VALUES ('5', '5', '319.00', '2024-06-06 22:07:42');
  18. INSERT INTO `user_wallet` VALUES ('6', '6', '350.00', '2024-06-08 22:07:42');
  19. INSERT INTO `user_wallet` VALUES ('7', '7', '871.00', '2024-06-04 22:07:42');
  20. INSERT INTO `user_wallet` VALUES ('8', '8', '515.00', '2024-06-05 22:07:42');
  21. INSERT INTO `user_wallet` VALUES ('9', '9', '1042.00', '2024-06-05 22:07:42');
  22. INSERT INTO `user_wallet` VALUES ('10', '10', '273.00', '2024-06-03 22:07:42');
  23. -- 插入10条用户钱包交易日志数据
  24. INSERT INTO `user_wallet_log` VALUES ('1', '1', '充值', '100.00', '2024-06-01 22:07:48');
  25. INSERT INTO `user_wallet_log` VALUES ('2', '2', '消费', '50.00', '2024-06-08 22:07:48');
  26. INSERT INTO `user_wallet_log` VALUES ('3', '3', '提现', '200.00', '2024-06-09 22:07:48');
  27. INSERT INTO `user_wallet_log` VALUES ('4', '4', '充值', '150.00', '2024-05-31 22:07:48');
  28. INSERT INTO `user_wallet_log` VALUES ('5', '5', '消费', '75.00', '2024-06-04 22:07:48');
  29. INSERT INTO `user_wallet_log` VALUES ('6', '6', '提现', '300.00', '2024-06-02 22:07:48');
  30. INSERT INTO `user_wallet_log` VALUES ('7', '7', '充值', '250.00', '2024-06-09 22:07:48');
  31. INSERT INTO `user_wallet_log` VALUES ('8', '8', '消费', '120.00', '2024-06-07 22:07:48');
  32. INSERT INTO `user_wallet_log` VALUES ('9', '9', '提现', '400.00', '2024-06-08 22:07:48');
  33. INSERT INTO `user_wallet_log` VALUES ('10', '10', '充值', '300.00', '2024-05-31 22:07:48');

product相关

  1. INSERT INTO `product_type` VALUES ('1', '智能手机', null, '包含各种品牌和型号的智能手机,涵盖不同价格区间和功能特点。', '2024-05-31 22:13:55');
  2. INSERT INTO `product_type` VALUES ('2', '笔记本电脑', null, '提供多种类型和配置的笔记本电脑,适用于不同工作和学习需求。', '2024-06-01 22:13:55');
  3. INSERT INTO `product_type` VALUES ('3', '智能家居', null, '包含智能家居设备,如智能音箱、智能照明、智能门锁等。', '2024-06-02 22:13:55');
  4. INSERT INTO `product_type` VALUES ('4', '电视与显示器', null, '涵盖各种尺寸和分辨率的电视与显示器,适用于家庭和企业使用。', '2024-06-03 22:13:55');
  5. INSERT INTO `product_type` VALUES ('5', '耳机与音响', null, '提供高品质耳机和音响设备,满足用户的音频体验需求。', '2024-06-04 22:13:55');
  6. INSERT INTO `product` VALUES ('1', 'iPhone 13', '6999.00', '100', '1', '2024-06-05 22:13:55');
  7. INSERT INTO `product` VALUES ('2', 'MacBook Pro', '14999.00', '50', '2', '2024-06-06 22:13:55');
  8. INSERT INTO `product` VALUES ('3', '小米智能音箱', '199.00', '200', '3', '2024-06-07 22:13:55');
  9. INSERT INTO `product` VALUES ('4', '三星65寸4K电视', '7999.00', '80', '4', '2024-06-08 22:13:55');
  10. INSERT INTO `product` VALUES ('5', '索尼降噪耳机', '1299.00', '150', '5', '2024-06-09 22:13:55');
  11. INSERT INTO `product` VALUES ('6', '华为MatePad Pro', '3999.00', '70', '2', '2024-05-31 22:13:55');
  12. INSERT INTO `product` VALUES ('7', '小米米家智能灯泡', '79.00', '300', '3', '2024-06-01 22:13:55');
  13. INSERT INTO `product` VALUES ('8', 'LG 27寸显示器', '1499.00', '120', '4', '2024-06-02 22:13:55');
  14. INSERT INTO `product` VALUES ('9', '苹果AirPods Pro', '1599.00', '90', '5', '2024-06-03 22:13:55');
  15. INSERT INTO `product` VALUES ('10', '一加9 Pro', '4999.00', '60', '1', '2024-05-30 22:13:55');

DQL 

  1. delimiter $$ -- 分隔符
  2. create trigger after_inster_user -- 创建触发器的名称
  3. after insert on `user` -- 用户表执行插入操作之后被出发的触发器
  4. for each row -- 每行数据都要进行触发
  5. begin
  6. #insert into `user` values(0,'散兵','password88','sanbing@qq.com','1234567890','2024-06-17 22:07:39');
  7. #能添加但执行插入语句时报错1442 - Can't update table 'user' in stored function/trigger because it is already used by statement which invoked this stored function/trigger.
  8. #1. MYSQL中触发器中不能对本表进行 insert ,update ,delete操作,以免递归循环触发
  9. #2. 对于update 只能用set进行操作,insert与delete只能借助第二张表才能实现需求,如果可以最好用存储过程代替触发器
  10. #3. 注意唯一索引不能有重复值
  11. INSERT INTO user_wallet (user_id, balance) -- 在user_wallet表中插入一行数据
  12. VALUES (NEW.user_id, 0.00); -- 使用NEW.user_id作为新插入行的user_id,balance为0.00
  13. end ;
  14. $$
  15. delimiter ; -- 结束$$的有效性更换成;

输出 

  1. delimiter $$
  2. create trigger after_insert_user
  3. before insert on `user`
  4. for each row
  5. begin
  6. signal sqlstate '45000' set message_text = '我们人为的停止了数据commit';
  7. # signal sqlstate '45000' 代表错误,会停止操作,包含插入语句也会取消commit操作
  8. end;
  9. $$
  10. delimiter $$

删 

  1. delete from `user` where user_id=5;
  2. # 报错,删除用户前需要删除从表的数据。
  3. delimiter $$
  4. create trigger delete_info_user
  5. before delete on `user`
  6. for each row
  7. begin
  8. delete from user_wallet where user_id=old.user_id;
  9. delete from user_wallet_log where user_id=old.user_id;
  10. end;
  11. $$
  12. delimiter ;
  13. delete from `user` where user_id=5;
  14. #成功

  1. delimiter $$
  2. create trigger product_update_price
  3. before update on product
  4. for each row
  5. begin
  6. -- 编写代码的区域
  7. declare result decimal(10,4); -- 声明变量,必须在头部。
  8. if new.price=0 then
  9. signal sqlstate '45000' set message_text='新价格不能为0。';
  10. end if;
  11. set result =(new.price-old.price)/old.price*100;
  12. if abs(result)>10 then -- abs():返回绝对值
  13. signal sqlstate '45000' set message_text = '价格上下浮动不能超过10%。';
  14. end if;
  15. end;
  16. $$
  17. delimiter ;

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/人工智能uu/article/detail/735428
推荐阅读
相关标签
  

闽ICP备14008679号