在Navicat for MySQL 中怎么创建触发器?

在Navicat for MySQL 中怎么创建触发器?,第1张

将delimiter 更改为delimiter //\x0d\x0a如下:\x0d\x0amysql>delimiter //\x0d\x0amysql>create trigger insertArticle_Trigger after insert on article1\x0d\x0a->for each row\x0d\x0a->begin\x0d\x0a->update board1 set articleCount = articleCount+1 where id=new.bid\x0d\x0a->end\x0d\x0a->//\x0d\x0a\x0d\x0a执行如下语句,可查看到board1表articleCount被更改:\x0d\x0amysql>delimiter \x0d\x0amysql>insert into article1 values(1)\x0d\x0a\x0d\x0a其中delimiter作用:\x0d\x0a告诉mysql解释器,该段命令是否已经结束了,mysql是否可以执行了。 \x0d\x0a默认情况下,delimiter是分号。在命令行客户端中,如果有一行命令以分号结束, 那么回车后,mysql将会执行该命令。但有时候,不希望MySQL这么做。在为可能输入较多的语句,且语句中包含有分号。使用delimiter //,这样只有当//出现之后,mysql解释器才会执行这段语句。详见

希望你自己写 ,做2个触发器,

第一个触发后可以做对overtime插入 *** 作,这里你没说触发类型????

Create Trigger '增加加班信息'

On overtime--在overtime表中创建触发器

for ????? ----触发的事件

As--事件触发后所要做的事情

begin

insert INTO overtime(你要加的信息)

end

第二个 基于overtime 表的触发update类的 更新加班信息

Create Trigger '修改考勤信息表'

On overtime--在overtime表中创建触发器

for insert --触发的事件

As--事件触发后所要做的事情

if Update(某字段)

begin

Update attend

set 你做overtime的插入后 attend 应该的变化

From attend,Inserted i --Inserted临时表

Where attend.emp_id =i.emp_id

end

做完之后 你插入几次检测下数据,再写上报错和其它

BEGIN与END之间的“执行语句列表”参数表示需要执行的多个执行语句的内容。不同的执行语句之间用分号隔开。

注意:

一般情况下,MySQL默认是以“”作为结束执行语句。在创建触发器过程中需要用到“”。为了解决这个问题,可以用DELIMITER语句。如“DELIMITER

&&”,可以将结束符号变成“&&”。当触发器创建完成后,可以用命令“DELIMITER

”来将结束符号变成“”。

实例

创建一个由DELETE触发多个执行语句的触发器dept_trig2。

1. 创建dept_trig2触发器的SQL代码如下:

DELIMITER &&

CREATE TRIGGER dept_trig2 AFTER DELETE

ON department FOR EACH ROW

BEGIN

INSERT INTO trigger_time VALUES('22:30:30')

INSERT INTO trigger_time VALUES('23:50:50')

END

&&

DELIMITER

在DOS提示符窗口中查看创建dept_trig2触发器的 *** 作效果。如下图所示:

上图中代码执行的结果显示,触发器创建成功。

2. 在department表中执行DELETE *** 作。如下图所示:

上图中代码执行的结果显示,删除 *** 作执行成功。

3. 在department表中执行DELETE *** 作以后,trigger_time表中将会自动插入两条记录。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/7246508.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-03
下一篇 2023-04-03

发表评论

登录后才能评论

评论列表(0条)

保存