我是靠谱客的博主 甜蜜百合,最近开发中收集的这篇文章主要介绍销售系统数据库触发器MySQL_mysql数据库触发器详解,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

2.1   Mysql触发器的基本使用

创建触发器。创建触发器语法如下:

CREATE TRIGGER trigger_name trigger_time trigger_event

ON tbl_name FOR EACH ROW trigger_stmt

其中trigger_name标识触发器名称,用户自行指定;

trigger_time标识触发时机,用before和after替换;

trigger_event标识触发事件,用insert,update和delete替换;

tbl_name标识建立触发器的表名,即在哪张表上建立触发器;

trigger_stmt是触发器程序体;触发器程序可以使用begin和end作为开始和结束,中间包含多条语句;

下面给出sfrd一个触发器实例:

CREATE /*!50017 DEFINER = 'root'@'localhost' */ TRIGGER trig_useracct_update

AFTER UPDATE

ON SF_User.useracct FOR EACH ROW

BEGIN

IF OLD.ulevelid = 10101 OR OLD.ulevelid = 10104 THEN

IF NEW.ulevelid = 10101 OR NEW.ulevelid = 10104 THEN

if NEW.ustatid != OLD.ustatid OR NEW.exbudget != OLD.exbudget THEN

INSERT into FC_Output.fcevent set type = 2, tabid = 1, level = 1, userid = NEW.userid, ustatid = NEW.ustatid, exbudget = NEW.exbudget;

end if;

ELSE

INSERT into FC_Output.fcevent set type = 1, tabid = 1, level = 1, userid = NEW.userid, ustatid = NEW.ustatid, exbudget = NEW.exbudget;

END IF;

END IF;

END;

上述触发器实例使用了OLD关键字和NEW关键字。OLD和NEW可以引用触发器所在表的某一列,在上述实例中,OLD.ulevelid表示表SF_User.useracct修改之前ulevelid列的值,NEW.ulevelid表示表SF_User.useracct修改之后ulevelid列的值。另外,如果是insert型触发器,NEW.ulevelid也表示表SF_User.useracct新增行的ulevelid列值;如果是delete型触发器OLD.ulevelid也表示表SF_User.useracct删除行的ulevelid列原值。

另外,OLD列是只读的,NEW列则可以在触发器程序中再次赋值。

上述实例也使用了IF,THEN ,ELSE,END IF等关键字。在触发器程序体中,在beigin和end之间,可以使用顺序,判断,循环等语句,实现一般程序需要的逻辑功能。

查看触发器。查看触发器语法如下,如果知道触发器所在数据库,以及触发器名称等具体信息:

SHOW TRIGGERS from SF_User like "usermaps%";       //查看SF_User库上名称和usermaps%匹配的触发器

如果不了解触发器的具体的信息,或者需要查看数据库上所有触发器,如下:

SHOW TRIGGERS;       //查看所有触发器

举例:

//添加

CREATE TRIGGER trig_insert_user

AFTER INSERT

ON test.ttt FOR EACH ROW

BEGIN

INSERT into ttt.user set username=NEW.name;

END

//删除

CREATE TRIGGER trig_delete_user

AFTER DELETE

ON test.ttt FOR EACH ROW

BEGIN

DELETE from ttt.user where username=OLD.name;

END

//更新

CREATE TRIGGER trig_update_user

AFTER UPDATE

ON test.ttt FOR EACH ROW

BEGIN

UPDATE ttt.user set username=NEW.name where

username=OLD.name;

END

最后

以上就是甜蜜百合为你收集整理的销售系统数据库触发器MySQL_mysql数据库触发器详解的全部内容,希望文章能够帮你解决销售系统数据库触发器MySQL_mysql数据库触发器详解所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(83)

评论列表共有 0 条评论

立即
投稿
返回
顶部