MySql存储过程

MySql存储过程

创建存储过程语法:
DELIMITER//
create procedure 名称()
begin
–语句–
end;//
这是一个没有参数的存储过程,注意名称后面要写括号();

调用存储过程语法:call 名称();
在这里插入图片描述

存储过程参数
DELIMITER//
create procedure 名称( [IN|OUT|INOUT] 参数名称 参数数据类型)
begin

end;//

存储过程的参数类型有三个,IN ,OUT, INOUT。

默认是IN类型,表示该参数的值必须在调用存储过程时指定,一般只用于传入。
在这里插入图片描述
OUT:参数传出,不能用于传入参数值,在调用存储过程中可以改变其值,并可返回,调用存储过程时,out参数也必须指定,但必须是变量,不能是常量。
在这里插入图片描述
INOUT:传入同时传出,调用时可传入值,在调用过程中,可修改其值,同时也可返回值,注意,传入的只能是变量;
在这里插入图片描述

DELIMITER的作用
就是告诉mysql解释器,该段命令是否已经结束了,mysql是否可以执行了。
mysql的执行,它遇到分号就会自动执行,有时候,不想这么做,因为可能会写较多的sql语句,这个时候就可以用DELIMITER改变输入结束符,把DELMITER后面换成其他符号,//或者$$,这就相当于对整个小段语句做了一个简单封装,有的mysql可能因为版本原因创建存储过程需要用DELIMITER。

存储过程的变量
声明变量需要用declare关键字,一句declare只声明一个变量,变量必须先声明后使用;
变量的数据类型和长度与mysql的sql数据类型保持一致;
返回变量可以使用select语句;
它的作用域在begin和end之内;
在这里插入图片描述
一个存储过程是一个可编程的函数,它在数据库中创建并保存。它可以有sql语句和一些特殊的控制语句组成。
数据库中的存储过程可以看做是对编程中面向对象方法的模拟。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值