MySQL学习笔记(8.存储函数,触发器)
创始人
2024-06-02 14:12:27

1. 存储函数

存储函数,是有返回值的存储过程,参数只能是in

存储函数有弊端,必须有返回值。存储函数能做的,存储过程都能做。

(1) 创建存储函数

create function 存储函数名(参数名 参数类型) // 参数无需指定in默认就是

returns 返回值类型

begin 

  sql..

  return ...;

end;

(2) 调用存储函数

select 存储函数名;

2. 触发器

触发器是,与表有关的数据在增删改之前或之后执行的语句集合。

Mysql只支持行级触发器(影响一行数据执行一次)

(1) 属性new与old

insert只有new属性

delete只有old属性

update 既有new 又有old

(2) 创建触发器

create trigger 触发器名

before/after insert/update/delete   // 之前/之后 插入/更新/删除,各选一个,例如 before insert

on 表名 for each row  // 行级触发器

begin

  sql..

end;

(3) 查看触发器

show triggers;

(4) 删除触发器

drop trigger [schema名.]触发器名;

(5) 示例

create grigger td_user_update_trigger

after update // 更新后执行触发器

on td_user for each row // td_user表的行级触发器

begin

  insert into tb_log values(old.id, new.id); // old.id 更新前id,new.id更新后id

end;

相关内容

热门资讯

打仗需要什么就专攻精练什么,在... 来源:中国军网-解放军报北部战区海军某部在任务一线检验理论学习成果——学用结合 为战砺剑■张腾飞 吴...
柳州部分地区出现塌陷坑,专家:... (来源:上观新闻)5月18日,广西柳州市柳南区发生地震后,辖区池塘、道路等接连出现圆形地面塌陷坑,引...
美加州圣迭戈市伊斯兰中心枪击事... (来源:上观新闻)当地时间5月18日,美国加利福尼亚州圣迭戈市警方表示,当地一家伊斯兰中心当天发生的...
广西柳州两次5.2级地震之间有...   来源:上观新闻  据中国地震台网正式测定,5月18日21时44分在广西柳州市柳南区再次发生5.2...
李在明喊话,三星电子劳资相互让... 【环球时报驻韩国特派记者 莽九晨】连日来,韩国三星电子劳资谈判引发韩国各界关注。据韩联社报道,三星电...