mysql通过触发器获取数据表的操作id_MySQL触发器初试:当A表插入新记录,自动在B表中插入相同ID的记录...

今天第一次用MySQL的触发器,怕忘了,赶紧写篇博客记录一下。

废话不说,先上语法:

1 CREATE TRIGGERtrigger_name2 { BEFORE | AFTER } { INSERT | UPDATE | DELETE}3 ONtbl_name4 FOREACH ROW5 trigger_body

事情的起因是这样的:我有一个人员信息表 pers。因为字段很多,就把中文字段单出来,另建了一个表 perscn。我希望当 pers 插入一条记录,perscn 也能自动插入一条记录,这样就能保证两张表的记录一一对应。MySQL中的触发器正好满足这个需求。不过也是研究了半天才最终搞定。

先上代码:

1 CREATE TRIGGERt_pers_perscn2 AFTER INSERT ONpers3 FOREACH ROW4 INSERT INTO perscn(pid, sname, oname, unic) VALUES(5 (SELECT MAX(pid) FROMpers),6 (SELECT sname FROM pers ORDER BY pid DESC LIMIT 1),7 (SELECT oname FROM pers ORDER BY pid DESC LIMIT 1),8 (SELECT unic FROM pers ORDER BY pid DESC LIMIT 1)9 );

以上代码大致是说:

1 创建触发器 t_pers_perscn

2 在 pers 插入新记录之后

3 对于每一条记录

4 往 perscn 插入一条记录,包含 4 个字段,值分别是(

5 (pid),

6 (sname),

7 (oname),

8 (unic)

9 );

因为需要获取 pers 表中插入记录的 ID(本表中字段名为 pid),一开始想着用 LAST_INSERT_ID(),行不通。后来想到 MAX(),倒是能获得最新插入的 pid 值,但 perscn 中的其它值却不能用 SELECT sname FROM pers WHERE pid = MAX(pid); 来获取,看来在 WHERE 语句中是不能用 MAX() 函数吧…… 最后只能用笨办法,先对 pid 进行降序排列,然后用 LIMIT 限制 1 条记录,这样倒是也能获得与 MAX() 函数相同的效果。没办法,就是这么笨……

回到最上面的语法,大致意思是:

1 CREATE TRIGGER 触发器名称2 在 INSERT、UPDATE或DELETE动作之前或之后

3 ON 上述动作所作用的表

4 FOR EACH ROW(规定语句,照抄吧)

5 以上动作所触发的SQL语句(即正常SQL操作语句)

其中,第5步的 trigger_body 一般只能写一行。如果有多条操作语句,则需要先用 DELIMITER 暂时更改下语句结束符,然后用 BEGIN...END... 语句来写操作语句(因为BEGIN...END...里必须用半角分号 “;” 来标识一行语句的结束,所以才需要用 DELIMITER)。关于更改 DELIMITER,请见官方文档的示例:

1 mysql> delimiter //

2 mysql> CREATE PROCEDURE dorepeat(p1 INT)3 -> BEGIN

4 -> SET @x = 0;5 -> REPEAT SET @x = @x + 1; UNTIL @x > p1 ENDREPEAT;6 -> END

7 -> //

8 Query OK, 0 rows affected (0.00sec)9 mysql> delimiter ;

触发器真是个好东西,自动化的神器啊…… 改天好好再研究研究、发掘发掘~~~

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值