[首页]
[文章]
[教程]
首页
Web开发
Windows开发
编程语言
数据库技术
移动平台
系统服务
微信
设计
布布扣
其他
数据分析
首页
>
数据库技术
> 详细
MySQL 存储过程传参之in, out, inout 参数用法
时间:
2016-09-24 17:41:03
阅读:
222
评论:
0
收藏:
0
[点我收藏+]
存储过程
传参:存储过程的括号里,可以声明参数。 语法是 create procedure p([in/out/inout] 参数名 参数类型 ..)
in :给参数传入值,定义的参数就得到了值
out:模式定义的参数只能在过程体内部赋值,表示该参数可以将某个值传递回调用他的过程(在存储过程内部,
该参数初始值为 null,无论调用者是否给存储过程参数设置值)
inout:
调用者还可以通过 inout 参数传递值给存储过程,也可以从存储过程内部传值给调用者
如果仅仅想把数据传给 MySQL 存储过程,那就使用“in” 类型参数;
如果仅仅从 MySQL 存储过程返回值,那就使用“out” 类型参数;
如果需要把数据传给 MySQL 存储过程,还要经过一些计算后再传回给我们,此时,要使用“inout” 类型参数。
DELIMITER $$
CREATE
PROCEDURE p1(
IN num
INT)
BEGIN
DECLARE i
INT
DEFAULT 0;
DECLARE total
INT
DEFAULT 0;
WHILE i<=num DO
SET total := i + total;
SET i := i+1;
END WHILE;
SELECT total;
END$$
存储过程传参 out
[sql]
view plain
copy
CREATE
PROCEDURE p2(
OUT num
INT)
BEGIN
SELECT num
AS num_1;
IF (num
IS
NOT
NULL)
THEN
SET num = num + 1;
SELECT num
AS num_2;
ELSE
SELECT 1
INTO num;
END IF;
SELECT num
AS num_3;
END$$
SET @num = 10$$
CALL p2(@num)$$
SELECT @num
AS num_out$$
CREATE
PROCEDURE p3(INOUT age
INT)
BEGIN
SET age := age + 20;
END$$
set @currage =18$$
call p3(@currage)$$
select @currage$$
MySQL 存储过程传参之in, out, inout 参数用法
原文:http://www.cnblogs.com/kabi/p/5903491.html
踩
(
0
)
赞
(
0
)
举报
评论
一句话评论(
0
)
登录后才能评论!
分享档案
更多>
2021年09月23日 (328)
2021年09月24日 (313)
2021年09月17日 (191)
2021年09月15日 (369)
2021年09月16日 (411)
2021年09月13日 (439)
2021年09月11日 (398)
2021年09月12日 (393)
2021年09月10日 (160)
2021年09月08日 (222)
最新文章
更多>
2021/09/28 scripts
2022-05-27
vue自定义全局指令v-emoji限制input输入表情和特殊字符
2022-05-27
9.26学习总结
2022-05-27
vim操作
2022-05-27
深入理解计算机基础 第三章
2022-05-27
C++ string 作为形参与引用传递(转)
2022-05-27
python 加解密
2022-05-27
JavaScript-对象数组里根据id获取name,对象可能有children属性
2022-05-27
SQL语句——保持现有内容在后面增加内容
2022-05-27
virsh命令文档
2022-05-27
教程昨日排行
更多>
1.
list.reverse()
2.
Django Admin 管理工具
3.
AppML 案例模型
4.
HTML 标签列表(功能排序)
5.
HTML 颜色名
6.
HTML 语言代码
7.
jQuery 事件
8.
jEasyUI 创建分割按钮
9.
jEasyUI 创建复杂布局
10.
jEasyUI 创建简单窗口
友情链接
汇智网
PHP教程
插件网
关于我们
-
联系我们
-
留言反馈
- 联系我们:wmxa8@hotmail.com
© 2014
bubuko.com
版权所有
打开技术之扣,分享程序人生!