Mysql存储过程

一、存储过程
1、概念
为了完成特定功能sql语句的集合,把定义好的的sql集合在一个特定的sql函数当中,每次执行调用函数即可,还可以实现传参的调用

2、作用
执行速度要比sql语句执行速度更快,执行效率也更高

客户端可以随时调用发放,也可以随时修改,可以对数据库做任何操作,

3、语法
创建库和表

create database xy102;

create table info1 (
id int(2) primary key,
name varchar(10),
high int(3),
address varchar(15)
);

3.1 delimiter $$
delimiter是开始和结束语法,$$是标志位,可以自定义,不要用汉字或者数字开头,不能使用特殊字符开头

delimiter $$
create procedure test1 ()
begin
 select * from info1;
end $$
delimiter;

# 查看存储过程命令
1.1 show procedure status where db='xy102';
1.2 show procedure status like '%test1%';

# 直接在表中编辑信息后,执行存储命令id=1,name=小戴,high=167,address=南京

# 执行存储过程命令
call test1;

delimiter $$
create procedure test2 ()
begin
 select * from info1;
 update info1 set high=180 where id = 1;
end $$
delimiter;
 
call test2;

3.2 存储过程传参
in 传入参数,调用者向存储过程传入值
out 输出参数,存储过程向调用者传出值,可以是多个值
inout 输入输出 既可以表示存储过程向调用者传出,也可以表示用户向存储过程传入值

delimiter $$
create procedure test3 (in uname char(20))
BEGIN
 SELECT * from info1 where name = uname;
END $$
delimiter;

# 直接在表中编辑信息后,执行存储命令id=2,name=小黄,high=172,address=南京

call test3 ('小黄');
# 显示信息为name=小黄的行

3.3 输出参数

delimiter $$ 
create procedure test4(
out id int,
out name char(10),
out high int,
out address varchar(10)
 )
 begin 
set id=3,name='王心凌',high=185,address ='幸云教育';
end $$
delimiter;

call test4(@id,@name,@high,@address)
select @id,@name,@high,@address;
insert into info1 values(@id,@name,@high,@address);

3.4 输入输出参数
在存储过程当中存储过程是不需要加@的

delimiter $$ 
create procedure test7(inout str varchar(10))
begin
select str;
# 在存储过程当中存储过程是不需要加@的
set str=concat(str,'_xy102');
# 替换 把字符换成进行替换
select str;
end $$
delimiter;

set @str='蔡依林';
call test7(@str);

update info1 set name=@str where id = 3;


# 把王心凌 high=185改成王心凌 high=195

delimiter $$ 
create procedure test8(inout ht varchar(10))
begin
set ht=ht+10;
end $$
delimiter;

set @ht=185;
call test8(@ht);

update info1 set name=@ht where id = 3;

3.5 存储过程的控制语句

delimiter $$ 
create procedure test9(inout num int)
begin
if num >=10 then
set num=num-5;
else
set num=num*2;
end if
end $$
delimiter;

set @num=19

call test9(@num)

update info1 set id=@num where high =111;

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值