MYSQL(七)存储过程

存储过程和函数:类似JAVA中的方法

好处:

1、提高代码重用性

2、简化操作

 

存储过程

含义:一组预先编译好的SQL语句的集合,理解成批处理语句

1、提高代码的重用性

2、简化操作

3、减少了编译次数并且减少了和数据库服务器的连接次数,提高了效率

 

一、创建语法(需在命令提示框中创建)

CREATE PROCEDURE 存储过程名(参数列表)

BEGIN

          存储过程体(一组合法的SL语句)

END

注意:

1、参数列表包含三部分

参数模式 参数名  参数类型

例如:

IN stuname VARCHAR(20)

参数模式:

IN:该参数可以作为输入,也就是该参数需要调用方传入值

OUT:该参数可以作为输出,也就是该参数可以作为返回值

INOUT:该参数既可以作为输入也可以作为输出,也就是该参数既需要传入值,也可以返回值

2、如果存储过程体仅仅只有一句话,BEGIN END可以省略

存储过程体重的每条SQL语句的结尾要求必须加分号

存储过程的结尾可以使用DELIMITER重新设置

语法:

DELIMITER 结束标记

例如:

DELIMITER $

二、调用语法(需在命令提示符中调用)

CALL 存储过程名(实参列表);

创建存储过程:

delimiter $

create procedure myp3(in user varchar(20),in password varchar(20))
begin
             declare result int default 0;
       select count(*) into result
             from users 
             where username=user and users.password=password;
             
             select if(result>0,'成功','失败');
end $

调用存储过程:

call myp2('ztt','123') $

 

 

create procedure myp3(in beautyName varchar(20),out boyName varchar(20))

begin

       select bo.boyName into boyName

from boys bo

inner join beauty b on bo.id=b.boyfriend_id

where b.name = beautyName;

end $

 

调用:

set @bName$ #此句可省

CALL myp3('小强',@bName)$

select @bName$

 

create procedure myp6(in beautyName varchar(20),out boyName varchar(20),out userCP int)

begin

     select bo.boyName,bo.userCP into boyName,userCP

      from boys bo

      inner join beauty b on bo.id=b.boyfriend_id

      where b.name=beautyName;

end $

 

调用

CALL myp6('小昭',@bName,@usercp)$

 

create procedure myp8(inout a int,inout b int)

begin

           set a=a*2;

           set b=b*2;

end $

调用:

set @m=10$

set @n=20$

CALL myp8(@m,@n)$

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值