前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Mysql触发器

Mysql触发器

作者头像
码客说
发布2019-10-22 14:48:05
4.5K0
发布2019-10-22 14:48:05
举报
文章被收录于专栏:码客码客

数据库中除了需要定时完成一些任务外,有时我们也想在某些表数据变化时自动执行些操作,这就要用到触发器了

基本语法

代码语言:javascript
复制
-- 删除已有同名触发器
DROP TRIGGER IF EXISTS trigger_name;
-- 创建新触发器
CREATE TRIGGER trigger_name 
trigger_time trigger_event 
ON tbl_name 
FOR EACH ROW
BEGIN
    trigger_stmt;
END;

其中: trigger_name:标识触发器名称,用户自行指定; trigger_time:标识触发时机,取值为 BEFOREAFTERtrigger_event:标识触发事件,取值为 INSERTUPDATEDELETEtbl_name:标识建立触发器的表名,即在哪张表上建立触发器; trigger_stmt:触发器程序体,可以是一句SQL语句,或者用 BEGINEND 包含的多条语句。

触发条件

INSERT 型触发器:插入某一行时激活触发器,可能通过 INSERTLOAD DATAREPLACE 语句触发; UPDATE 型触发器:更改某一行时激活触发器,可能通过 UPDATE 语句触发; DELETE 型触发器:删除某一行时激活触发器,可能通过 DELETEREPLACE 语句触发。

简单例子

如果设置 或定义变量 要按照一下的格式写

比如修改数据前 修改要插入的数据

代码语言:javascript
复制
delimiter $$
DROP TRIGGER IF EXISTS t_a_stage_group_score_before_insert$$
create trigger t_a_stage_group_score_before_insert
 before insert on a_stage_group_score
 FOR EACH ROW
 BEGIN 
	SET NEW.`avgscorepre` = (select avgscorenext from a_stage_group_score where schoolid=NEW.schoolid and groupid=NEW.groupid and subjectid=NEW.subjectid ORDER BY examtime desc limit 0,1);
 END; $$
delimiter ;

定义变量

mysql存储过程中,定义变量有两种方式:

  • 1.使用set或select直接赋值,变量名以 @ 开头. 例如: set @var=1; 可以在一个会话的任何地方声明,作用域是整个会话,称为会话变量。
  • 2.以 DECLARE 关键字声明的变量,只能在存储过程中使用,称为存储过程变量,例如: DECLARE max_rank INT DEFAULT 0; set max_rank = (select max(rank) from user ); 主要用在存储过程中,或者是给存储传参数中。 两者的区别是: 在调用存储过程时,以DECLARE声明的变量都会被初始化为 NULL。而会话变量(即@开头的变量)则不会被再初始化,在一个会话内,只须初始化一次,之后在会话内都是对上一次计算的结果,就相当于在是这个会话内的全局变量。 在存储过程中,使用动态语句,预处理时,动态内容必须赋给一个会话变量。 例:
代码语言:javascript
复制
set @v_sql= sqltext;
 PREPARE stmt FROM @v_sql;  
 EXECUTE stmt;     
 DEALLOCATE PREPARE stmt;

NEW 与 OLD

上述示例中使用了 NEW 关键字 MySQL 中定义了 NEWOLD,用来表示触发器的所在表中,触发了触发器的那一行数据。 具体: 在 INSERT 型触发器中,NEW 用来表示将要(BEFORE)或已经(AFTER)插入的新数据; 在 UPDATE 型触发器中,OLD 用来表示将要或已经被修改的原数据,NEW 用来表示将要或已经修改为的新数据; 在 DELETE 型触发器中,OLD 用来表示将要或已经被删除的原数据; 使用方法: NEW.columnName (columnName 为相应数据表某一列名)

if else

代码语言:javascript
复制
declare stu_grade float;  
select grade into stu_grade from grade where student_no=stu_no and course_no=cour_no;  
if stu_grade>=90 then 
    select stu_grade,'A';  
elseif stu_grade<90 and stu_grade>=80 then 
    select stu_grade,'B';  
else 
    select stu_grade,'C';  
end if;

查看触发器

代码语言:javascript
复制
SHOW TRIGGERS;
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2018-07-13,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 基本语法
  • 触发条件
  • 简单例子
  • 定义变量
  • NEW 与 OLD
  • if else
  • 查看触发器
相关产品与服务
对象存储
对象存储(Cloud Object Storage,COS)是由腾讯云推出的无目录层次结构、无数据格式限制,可容纳海量数据且支持 HTTP/HTTPS 协议访问的分布式存储服务。腾讯云 COS 的存储桶空间无容量上限,无需分区管理,适用于 CDN 数据分发、数据万象处理或大数据计算与分析的数据湖等多种场景。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档