欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

mysql心得分享:存储过程

程序员文章站 2024-02-29 10:54:40
use test; drop table if exists t8; create table t8(s1 int,primary key(s1));...
use test;

drop table if exists t8;
create table t8(s1 int,primary key(s1));

drop procedure if exists handlerdemo;

delimiter $$
create procedure handlerdemo()
begin
declare xx int default 4;
declare oh_no condition for sqlstate '23000';
#declare continue handler for sqlstate '23000' set @x2=1;
declare exit handler for oh_no set @info='违反主键约束';
set @x=1;
insert into t8 values(1);
set @x=2;
insert into t8 values(1);
set @x=3;
end

调用存储过程

/* 调用存储过程*/
call handlerdemo();

/* 查看调用存储过程结果*/
select @x,@info;

心得体会:

1、语句结束符

也许mysql是将存储过程、自定义函数看作一条语句的,因此,存储过程里多条语句用“;”隔开,为了避免冲突,就要用delimiter 重新定义结束符。

一般可以在存储过程开始前,定义新的结束符,如

delimiter //

存储过程书写完毕以后,再恢复定义:delimiter ;

但也可以在存储过程开始前,这样写 delimiter $$,但存储过程后不可以再写别的语句了。如上面的例子

2、变量

mysql的变量,跟sql server一样,形如 @x ,但无需声明,直接使用。

而在存储过程里面,变量无须用 @,但要声明。并且声明要放在存储过程的头部(?),如本例,否则报错。真奇怪啊,一方面,有时候变量无须声明就可以使用,另一方面,有时候又要限定声明位置,令人无所适从,似乎随便了点。

存储过程内部的变量,作用范围仅限于存储过程。但那些带@的变量,却仿佛可以跨越会话和连接,看上去是全局变量?如上面的例子。

3、条件和处理

定义条件,是为了给处理调用。如上面的例子:

declare oh_no condition for sqlstate '23000';
#declare continue handler for sqlstate '23000' set @x2=1;
declare exit handler for oh_no set @info='违反主键约束';