mysql触发器和存储过程_MySql的存储过程和触发器

本文详细介绍了MySQL中的存储过程和触发器。存储过程允许开发者定义带参数的SQL序列,支持循环、条件判断等控制结构,可用于数据的批量处理。创建时需更改语句结束符,如使用//,并通过`CREATE PROCEDURE`定义。调用时使用`CALL`。触发器则在特定数据操作前或后自动执行,常用于保证数据一致性。定义触发器使用`CREATE TRIGGER`,示例中展示了如何在更新用户表前检查管理员权限。删除存储过程和触发器分别用`DROP PROCEDURE`和`DROP TRIGGER`。存储过程和触发器是数据库管理中的重要工具,用于实现复杂业务逻辑。

Mysql的存储过程是类似于其它编程语言中的函数的功能,存储过程内部可以使用顺序循环和转移三种基本程序结构,而且整个存储过程可以接受和返回参数。

创建存储过程(procedure)时,因为其内部有以;结尾的sql语句,所以我们要更改语句结束符,使用delimiter  //来更改结束符为//。然后就可以定义了,eg

create procedure name()

begin

declare a int(10);

set a = 1;

while a<10 do

if a%2 = 1 then

set a = a+1;

insert into users values (null,a,’’,’’);

else

set a=a+1;

end if;

end while;

end //

调用时直接使用call name()来就可以,注意要带()。

显示创建过程用show create procedure name

显示所有存储过程用show procedure status

删除存储过程用 drop procedure name

存储过程内可以使用字符串,时间和数学函数。同时可以在参数列表中定义传入和传出的参数,定义输出参数 out a int,在存储过程内部给这个变量@a赋值,显示时用select @a。

Mysql的触发器相当于内部处理的一些过程,他不带入和带出任何的参数,其内部使用的参数就是新旧两条记录old和new的字段。用于完成数据表之间的触发操作,来保证数据库的一致性、完整性。

定义触发器的规程:

create trigger name after|before delete|update|insert on table_name for each row begin end 当有多个语句的时候就用begin和end,不可以有多个相同时间点的相同类型操作。Eg

Create trigger name before update on users

For each row

Begin

If new.admin = 1 then

Set new.admin =1;

Else

Set new.admin =0;

End if;

End

调用触发器,当在表上出现制定的操作时,执行相应的触发器。

删除触发器drop trigger name

用途举例:同步插入数据至不同类型的表,同步删除关联数据。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值