加入收藏 | 设为首页 | 会员中心 | 我要投稿 开发网_运城站长网 (https://www.0359zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

MySQL-触发器

发布时间:2022-11-25 12:58:50 所属栏目:MySql教程 来源:
导读:  一、触发器

  触发器(TRIGGER)是MySQL的数据库对象之一,从5.0.2版本开始支持。该对象与编程语言中的函数非常类似,都需要声明、执行等。但是触发器的执行不是由程序调用,也不是由手工启动,而是由事件
  一、触发器
 
  触发器(TRIGGER)是MySQL的数据库对象之一,从5.0.2版本开始支持。该对象与编程语言中的函数非常类似,都需要声明、执行等。但是触发器的执行不是由程序调用,也不是由手工启动,而是由事件来触发、激活从而实现执行。有点类似DOM中的事件。触发器是由事件触发,事件包括增,删,改操作,当数据库执行这些操作时,会激活触发器执行相应的操作
 
  创建触发器的语法
 
  CREATE TRIGGER trigger_name trigger_time trigger_event
  ON tb_name FOR EACH ROW trigger_stmt
  trigger_name:触发器名称
  tirgger_time:触发执行事件
   BEFORE:事件之前触发
   AFTER:事件之后触发
  trigger_event:触发事件
   INSERT:插入某一行时激活触发器,INSERT,LOAD DATA,REPLACE语句可以触发
   UPDATE:更改某一行时激活触发器,UPDATE语句可以触发
   DELETE:删除某一行时激活触发器,DELETE,REPLACE语句可以触发
  tb_name:触发器要执行的哪张表
  FOR EACH ROW:触发频率为每一行触发一次
  trigger_stmt:触发器的程序体,可以是一条SQL语句或者是用BEGIN和END包含的多条语句
  1、创建只有一个执行语句的触发器
 
  CREATE TRIGGER 触发器名 BEFORE|AFTER 触发事件?ON 表名 FOR EACH ROW 执行语句;
  2、创建有多个执行语句的触发器
 
  CREATE TRIGGER 触发器名 BEFORE|AFTER 触发事件
  ON 表名 FOR EACH ROW
  BEGIN
  ??? ??? 执行语句列表
  END;
  MySQL默认是以 ;作为结束执行符号,与触发器执行语句列表中需要的分行起冲突,为解决此问题可用DELIMITER,如DELIMITER || ,就是将结束符号变成||。
 
  DELIMITER ||
  CREATE TRIGGER 触发器名 BEFORE|AFTER 触发事件
  ON 表名 FOR EACH ROW
  BEGIN
  ??? ??? 执行语句列表
  END ||
  DELIMITER;
  3、NEW和OLD
 
  MySQL中定义了NEW和OLD,用来记录发生变化的内容,具体为:INSERT:NEW用来表示将要(BEFORE)或已经(AFTER)插入的新数据;UPDATE:OLD用来表示将要或已经被修改的原数据,NEW用来表示将要或已经修改为的新数据;DELETE:OLD用来表示将要或已经被删除的原数据;使用方法: NEW.columnName (columnName 为相应数据表某一列名)
 
  4、示例
 
  创建用户(users)表,日志(logs)表
 
  CREATE TABLE `users` (
    `id` int(20) not null auto_increment primary key,
    `name` varchar(255)
  );
  CREATE TABLE `logs` (
    `nid` int(20) not null auto_increment primary key,
    `log` varchar(255)
  );
  创建触发器(每添加一个用户,就记录一条日志)
 
  delimiter //
  create trigger user_log after insert on users for each row
  begin
  insert into logs(log) values(new.name);
  end //
  delimiter ;
  使用触发器触发器无法由用户直接调用,而知由于对表的【增/删/改】操作被动引发的。
 
  insert into users(name) values('admin');
  查看触发器SHOW TRIGGERS语句查看触发器信息
 
  epoll水平触发和边缘触发_mysql触发器有什么用_mysql触发器
 
  删除触发器
 
  drop trigger user_log;
  5、触发器的作用
 
  数据库触发器有以下的作用:1.安全性。可以基于数据库的值使用户具有操作数据库的某种权利。可以基于时间限制用户的操作mysql触发器,例如不允许下班后和节假日修改数据库数据。可以基于数据库中的数据限制用户的操作,例如不允许股票的价格的升幅一次超过10%。2.审计。可以跟踪用户对数据库的操作。审计用户操作数据库的语句。把用户对数据库的更新写入审计表。3.实现复杂的数据完整性规则实现非标准的数据完整性检查和约束。触发器可产生比规则更为复杂的限制。与规则不同,触发器可以引用列或数据库对象。例如,触发器可回退任何企图吃进超过自己保证金的期货。提供可变的缺省值。4.实现复杂的非标准的数据库相关完整性规则。触发器可以对数据库中相关的表进行连环更新。例如,在auths表author_code列上的删除触发器可导致相应删除在其它表中的与之匹配的行。在修改或删除时级联修改或删除其它表中的与之匹配的行。在修改或删除时把其它表中的与之匹配的行设成NULL值。在修改或删除时把其它表中的与之匹配的行级联设成缺省值。触发器能够拒绝或回退那些破坏相关完整性的变化,取消试图进行数据更新的事务。当插入一个与其主健不匹配的外部键时,这种触发器会起作用。例如,可以在books.author_code列上生成一个插入触发器,如果新值与auths.author_code列中的某值不匹配时,插入被回退。5.同步实时地复制表中的数据。6.自动计算数据值,如果数据的值达到了一定的要求,则进行特定的处理。例如,如果公司的帐号上的资金低于5万元则立即给财务人员发送警告数据。
 

(编辑:开发网_运城站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!