第十七章、触发器.sql 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155
  1. #第十七章、触发器
  2. #0、准备工作
  3. CREATE DATABASE dbtest17;
  4. USE dbtest17;
  5. #1、如果创建触发器
  6. #举例1
  7. #①、创建数据表
  8. CREATE TABLE test_trigger (
  9. id INT PRIMARY KEY AUTO_INCREMENT,
  10. t_note VARCHAR(30)
  11. );
  12. CREATE TABLE test_trigger_log (
  13. id INT PRIMARY KEY AUTO_INCREMENT,
  14. t_log VARCHAR(30)
  15. );
  16. #②、查看表数据
  17. SELECT * FROM test_trigger;
  18. SELECT * FROM test_trigger_log;
  19. #③、创建触发器
  20. #创建触发器:创建名称为before_insert_test_tri的触发器,向test_trigger数据表插入
  21. #数据之前,向test_trigger_log数据表中插入before_insert的日志信息。
  22. DELIMITER //
  23. CREATE TRIGGER before_insert_test_tri
  24. BEFORE INSERT ON test_trigger
  25. FOR EACH ROW
  26. BEGIN
  27. INSERT INTO test_trigger_log(t_log)
  28. VALUES('before insert ...');
  29. END //
  30. DELIMITER ;
  31. #④、测试
  32. INSERT INTO test_trigger(t_note)
  33. VALUES('Tom ...');
  34. SELECT * FROM test_trigger;
  35. SELECT * FROM test_trigger_log;
  36. #举例2:
  37. #创建名称为after_insert_test_tri的触发器,向test_trigger数据表插入数据之后,
  38. #向test_trigger_log数据表中插入after_insert的日志信息。
  39. DELIMITER //
  40. CREATE TRIGGER after_insert_test_tri
  41. AFTER INSERT ON test_trigger
  42. FOR EACH ROW
  43. BEGIN
  44. INSERT INTO test_trigger_log(t_log)
  45. VALUES('affter insert ...');
  46. END //
  47. DELIMITER ;
  48. #测试
  49. INSERT INTO test_trigger(t_note)
  50. VALUES('Jerry ...');
  51. SELECT * FROM test_trigger;
  52. SELECT * FROM test_trigger_log;
  53. #举例3:
  54. #定义触发器“salary_check_trigger”,基于员工表“employees”的INSERT事件,
  55. #在INSERT之前检查将要添加的新员工薪资是否大于他领导的薪资,如果大于领导薪资,
  56. #则报sqlstate_value为'HY000'的错误,从而使得添加失败。
  57. #准备工作
  58. CREATE TABLE employees
  59. AS
  60. SELECT * FROM atguigudb.employees;
  61. CREATE TABLE departments
  62. AS
  63. SELECT * FROM atguigudb.departments;
  64. DESC employees;
  65. #创建触发器
  66. DELIMITER //
  67. CREATE TRIGGER salary_check_trigger
  68. BEFORE INSERT ON employees
  69. FOR EACH ROW
  70. BEGIN
  71. #查询到要添加的数据的manager的薪资
  72. DECLARE mgr_sal DOUBLE;
  73. SELECT salary INTO mgr_sal FROM employees
  74. WHERE employee_id = NEW.manager_id;
  75. IF NEW.salary > mgr_sal
  76. THEN SIGNAL SQLSTATE 'HY000' SET MESSAGE_TEXT = '薪资高于领导薪资错误';
  77. END IF;
  78. END //
  79. DELIMITER ;
  80. #测试
  81. #添加成功:依然触发了触发器salary_check_trigger的执行
  82. INSERT INTO employees(employee_id,last_name,email,hire_date,job_id,salary,manager_id)
  83. VALUES(300,'Tom','tom@126.com',CURDATE(),'AD_VP',8000,103);
  84. #添加失败
  85. INSERT INTO employees(employee_id,last_name,email,hire_date,job_id,salary,manager_id)
  86. VALUES(300,'Tom1','tom@126.com',CURDATE(),'AD_VP',10000,103);
  87. SELECT * FROM employees;
  88. #2、查看触发器
  89. #①、查看当前数据库的左右触发器的定义
  90. SHOW TRIGGERS;
  91. #②、方式2:查看当前数据库中某个触发器的定义
  92. SHOW CREATE TRIGGER salary_check_trigger;
  93. #③、方式3:从系统库information_schema的TRIGGERS表中查询“salary_check_trigger”触发器的信息。
  94. SELECT * FROM information_schema.TRIGGERS;
  95. #3、删除触发器
  96. DROP TRIGGER IF EXISTS after_insert_test_tri;