MySQL存储过程基础

MySQL存储过程基础

1、基本语法

create procedure 名称()
begin
   sql语句
end;

create procedure simple_procedure()
begin
select * from blog;
end;


--调用
call simple_procedure;

2、存储过程的变量

简单示例:

## 简单的存储过程
create procedure test2()
begin
	##使用declare定义一个变量
	declare val VARCHAR(32) DEFAULT("什么是快乐");
	declare val2 VARCHAR(32) ;
	## 使用set定义一个变量
	set @val3 ="";
	##使用set给变量赋值
	set val2 ='什么是快乐';
	##使用 select  into语句给变量赋值
	SELECT title into val3 from blog where id=1;
	## 方法的返回
	select val ,val2,val3;
end;

http://inews.gtimg.com/newsapp_ls/0/14444445921/0

小结:

  1. 使用declare定义变量,格式:declare 名称 类型 [default (默认值)]
  2. 一个declare只能定义一个变量,变量必须先声明在使用
  3. 变量具有数据类型和长度,与mysql的SQL数据类型保持一致,因此甚至还能制定默认值、字符集和排序规则等;
  4. 变量可以通过set来赋值,也可以通过select into的方式赋值;
  5. 变量需要返回,可以使用select语句,如:select 变量名。

变量作用域:

定义的变量在定义的begin 和end之间有用。end结束,变量的作用范围就结束了。如果需要多处begin下使用变量,将变量定义在所有begin之前。类比Java函数的全局变量和局部变量

3、存储过程参数

1、基本语法

create procedure 名称([IN|OUT|INOUT] 参数名 参数数据类型 )
begin
    .........
end

存储过程参数共有三种:IN、OUT、INOUT

IN

说明

  1. 传入参数:类型为in,表示该参数的值必须在调用存储过程事指定,如果不显示指定为in,那么默认就是in类型。
  2. IN类型参数一般只用于传入,在调用过程中一般不作为修改和返回(修改、返回的情况不会报错)
  3. 如果调用存储过程中需要修改和返回值,可以使用OUT类型参数

例:

 create procedure test3(param int)
 begin
 	select * from blog
 	where id=param
 end

http://inews.gtimg.com/newsapp_ls/0/14444609931/0

OUT

## out 存储参数
create PROCEDURE test5( param int,OUT titleValue varchar(32))
begin
 SELECT title into titleValue from blog where id=param;
 select titleValue;
END
##调用
set @titleValue="";
call test5(1,@titleValue)

http://inews.gtimg.com/newsapp_ls/0/14445018670/0

概括:

  1. 调用存储过程时,参数要加@,否则认为是常量;
  2. 传出参数:在调用存储过程中,可以改变其值,并可返回;
  3. out是传出参数,不能用于传入参数值;
  4. 调用存储过程时,out参数也需要指定,但必须是变量,不能是常量;
  5. 如果既需要传入,同时又需要传出,则可以使用INOUT类型参数

INOUT

INOUT具有 IN、OUT的所有特性

create procedure test6(inout param VARCHAR(32))
begin
	declare param2 varchar(32);
	set param2=param;
	set param="转载";
 select title into param from blog 
 where blogType=param;
 select param,param2;
end

http://inews.gtimg.com/newsapp_ls/0/14445314969/0

概括:
1、可变变量INOUT:调用时可传入值,在调用过程中,可修改其值,同时也可返回值;
2、INOUT参数集合了IN和OUT类型的参数功能;
3、INOUT调用时传入的是变量,而不是常量;

5、存储过程中的条件语句

基本结构

if() then...else...end if;
if() then...
elseif() then...
else ...
end if;

例子

create procedure test7(in val VARCHAR(32))
begin
	declare action varchar(32);
	if(val='我是人')
	  then set action='双脚走路';
	elseif(val='老虎')
	  then set action='四脚走路';
	else
	 set action='未知的生物';
	end if;
	select action;
END
set @x='我是人';
call test7(@x)

http://inews.gtimg.com/newsapp_ls/0/14448188849/0

6、循环语句

基本结构

while(表达式) do 
   ......  
end while;
create procedure testWhile()
BEGIN
	DECLARE x INT DEFAULT(0);
	DECLARE val VARCHAR(32) DEFAULT('');
	while(x<10) do
		set val=concat(val,'x');
		set x=x+1;
	end while;
	select val;
END

call testWhile();

http://inews.gtimg.com/newsapp_ls/0/14448771976/0

MySQL存储过程基础

1、基本语法

create procedure 名称()
begin
   sql语句
end;

create procedure simple_procedure()
begin
select * from blog;
end;


--调用
call simple_procedure;

2、存储过程的变量

简单示例:

## 简单的存储过程
create procedure test2()
begin
	##使用declare定义一个变量
	declare val VARCHAR(32) DEFAULT("什么是快乐");
	declare val2 VARCHAR(32) ;
	## 使用set定义一个变量
	set @val3 ="";
	##使用set给变量赋值
	set val2 ='什么是快乐';
	##使用 select  into语句给变量赋值
	SELECT title into val3 from blog where id=1;
	## 方法的返回
	select val ,val2,val3;
end;

http://inews.gtimg.com/newsapp_ls/0/14444445921/0

小结:

  1. 使用declare定义变量,格式:declare 名称 类型 [default (默认值)]
  2. 一个declare只能定义一个变量,变量必须先声明在使用
  3. 变量具有数据类型和长度,与mysql的SQL数据类型保持一致,因此甚至还能制定默认值、字符集和排序规则等;
  4. 变量可以通过set来赋值,也可以通过select into的方式赋值;
  5. 变量需要返回,可以使用select语句,如:select 变量名。

变量作用域:

定义的变量在定义的begin 和end之间有用。end结束,变量的作用范围就结束了。如果需要多处begin下使用变量,将变量定义在所有begin之前。类比Java函数的全局变量和局部变量

3、存储过程参数

1、基本语法

create procedure 名称([IN|OUT|INOUT] 参数名 参数数据类型 )
begin
    .........
end

存储过程参数共有三种:IN、OUT、INOUT

IN

说明

  1. 传入参数:类型为in,表示该参数的值必须在调用存储过程事指定,如果不显示指定为in,那么默认就是in类型。
  2. IN类型参数一般只用于传入,在调用过程中一般不作为修改和返回(修改、返回的情况不会报错)
  3. 如果调用存储过程中需要修改和返回值,可以使用OUT类型参数

例:

 create procedure test3(param int)
 begin
 	select * from blog
 	where id=param
 end

http://inews.gtimg.com/newsapp_ls/0/14444609931/0

OUT

## out 存储参数
create PROCEDURE test5( param int,OUT titleValue varchar(32))
begin
 SELECT title into titleValue from blog where id=param;
 select titleValue;
END
##调用
set @titleValue="";
call test5(1,@titleValue)

http://inews.gtimg.com/newsapp_ls/0/14445018670/0

概括:

  1. 调用存储过程时,参数要加@,否则认为是常量;
  2. 传出参数:在调用存储过程中,可以改变其值,并可返回;
  3. out是传出参数,不能用于传入参数值;
  4. 调用存储过程时,out参数也需要指定,但必须是变量,不能是常量;
  5. 如果既需要传入,同时又需要传出,则可以使用INOUT类型参数

INOUT

INOUT具有 IN、OUT的所有特性

create procedure test6(inout param VARCHAR(32))
begin
	declare param2 varchar(32);
	set param2=param;
	set param="转载";
 select title into param from blog 
 where blogType=param;
 select param,param2;
end

http://inews.gtimg.com/newsapp_ls/0/14445314969/0

概括:
1、可变变量INOUT:调用时可传入值,在调用过程中,可修改其值,同时也可返回值;
2、INOUT参数集合了IN和OUT类型的参数功能;
3、INOUT调用时传入的是变量,而不是常量;

5、存储过程中的条件语句

基本结构

if() then...else...end if;
if() then...
elseif() then...
else ...
end if;

例子

create procedure test7(in val VARCHAR(32))
begin
	declare action varchar(32);
	if(val='我是人')
	  then set action='双脚走路';
	elseif(val='老虎')
	  then set action='四脚走路';
	else
	 set action='未知的生物';
	end if;
	select action;
END
set @x='我是人';
call test7(@x)

http://inews.gtimg.com/newsapp_ls/0/14448188849/0

6、循环语句

基本结构

while(表达式) do 
   ......  
end while;
create procedure testWhile()
BEGIN
	DECLARE x INT DEFAULT(0);
	DECLARE val VARCHAR(32) DEFAULT('');
	while(x<10) do
		set val=concat(val,'x');
		set x=x+1;
	end while;
	select val;
END

call testWhile();

http://inews.gtimg.com/newsapp_ls/0/14448771976/0

MySQL存储过程基础

1、基本语法

create procedure 名称()
begin
   sql语句
end;

create procedure simple_procedure()
begin
select * from blog;
end;


--调用
call simple_procedure;

2、存储过程的变量

简单示例:

## 简单的存储过程
create procedure test2()
begin
	##使用declare定义一个变量
	declare val VARCHAR(32) DEFAULT("什么是快乐");
	declare val2 VARCHAR(32) ;
	## 使用set定义一个变量
	set @val3 ="";
	##使用set给变量赋值
	set val2 ='什么是快乐';
	##使用 select  into语句给变量赋值
	SELECT title into val3 from blog where id=1;
	## 方法的返回
	select val ,val2,val3;
end;

http://inews.gtimg.com/newsapp_ls/0/14444445921/0

小结:

  1. 使用declare定义变量,格式:declare 名称 类型 [default (默认值)]
  2. 一个declare只能定义一个变量,变量必须先声明在使用
  3. 变量具有数据类型和长度,与mysql的SQL数据类型保持一致,因此甚至还能制定默认值、字符集和排序规则等;
  4. 变量可以通过set来赋值,也可以通过select into的方式赋值;
  5. 变量需要返回,可以使用select语句,如:select 变量名。

变量作用域:

定义的变量在定义的begin 和end之间有用。end结束,变量的作用范围就结束了。如果需要多处begin下使用变量,将变量定义在所有begin之前。类比Java函数的全局变量和局部变量

3、存储过程参数

1、基本语法

create procedure 名称([IN|OUT|INOUT] 参数名 参数数据类型 )
begin
    .........
end

存储过程参数共有三种:IN、OUT、INOUT

IN

说明

  1. 传入参数:类型为in,表示该参数的值必须在调用存储过程事指定,如果不显示指定为in,那么默认就是in类型。
  2. IN类型参数一般只用于传入,在调用过程中一般不作为修改和返回(修改、返回的情况不会报错)
  3. 如果调用存储过程中需要修改和返回值,可以使用OUT类型参数

例:

 create procedure test3(param int)
 begin
 	select * from blog
 	where id=param
 end

http://inews.gtimg.com/newsapp_ls/0/14444609931/0

OUT

## out 存储参数
create PROCEDURE test5( param int,OUT titleValue varchar(32))
begin
 SELECT title into titleValue from blog where id=param;
 select titleValue;
END
##调用
set @titleValue="";
call test5(1,@titleValue)

http://inews.gtimg.com/newsapp_ls/0/14445018670/0

概括:

  1. 调用存储过程时,参数要加@,否则认为是常量;
  2. 传出参数:在调用存储过程中,可以改变其值,并可返回;
  3. out是传出参数,不能用于传入参数值;
  4. 调用存储过程时,out参数也需要指定,但必须是变量,不能是常量;
  5. 如果既需要传入,同时又需要传出,则可以使用INOUT类型参数

INOUT

INOUT具有 IN、OUT的所有特性

create procedure test6(inout param VARCHAR(32))
begin
	declare param2 varchar(32);
	set param2=param;
	set param="转载";
 select title into param from blog 
 where blogType=param;
 select param,param2;
end

http://inews.gtimg.com/newsapp_ls/0/14445314969/0

概括:
1、可变变量INOUT:调用时可传入值,在调用过程中,可修改其值,同时也可返回值;
2、INOUT参数集合了IN和OUT类型的参数功能;
3、INOUT调用时传入的是变量,而不是常量;

5、存储过程中的条件语句

基本结构

if() then...else...end if;
if() then...
elseif() then...
else ...
end if;

例子

create procedure test7(in val VARCHAR(32))
begin
	declare action varchar(32);
	if(val='我是人')
	  then set action='双脚走路';
	elseif(val='老虎')
	  then set action='四脚走路';
	else
	 set action='未知的生物';
	end if;
	select action;
END
set @x='我是人';
call test7(@x)

http://inews.gtimg.com/newsapp_ls/0/14448188849/0

6、循环语句

基本结构

while(表达式) do 
   ......  
end while;
create procedure testWhile()
BEGIN
	DECLARE x INT DEFAULT(0);
	DECLARE val VARCHAR(32) DEFAULT('');
	while(x<10) do
		set val=concat(val,'x');
		set x=x+1;
	end while;
	select val;
END

call testWhile();

http://inews.gtimg.com/newsapp_ls/0/14448771976/0

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值