Mysql:参数--in、out、inout和自定义函数create function

#复习

delimiter //

create procedure p0001()

begin

declare cname varchar(20);

declare id varchar(10);

declare num int;

set cname='人民邮电出版社';

set id=(select 出版社ID from 出版社信息 where 出版社名称=cname);

set num=(select count(*) from 图书信息 where 出版社=id);

select cname,id,num;

end //

delimiter ;

call p0001()

#参数格式: in(输入参数) |out(输出参数) | inout(同时具有in和out参数的特性)

#in参数

delimiter //

create procedure p0002(IN a varchar(20)) #输入参数a,将值通过a传入进去

begin

declare cname varchar(20);

declare id varchar(10);

declare num int;

set cname=a;

set id=(select 出版社ID from 出版社信息 where 出版社名称=cname);

set num=(select count(*) from 图书信息 where 出版社=id);

select cname,id,num;

end //

delimiter ;

call p0002('高等教育出版社') #调用,括号里的参数通过a传递进来

call p0002('清华大学出版社') #通过in输入参数,可以通过call多次调用不同的数据

#out参数

delimiter //

create procedure p0003(IN a varchar(20),OUT b int)

begin

declare cname varchar(20);

declare id varchar(10);

declare num int;

set cname=a;

set id=(select 出版社ID from 出版社信息 where 出版社名称=cname);

set num=(select count(*) from 图书信息 where 出版社=id);

set b=num;

end //

delimiter ;

call p0003('高等教育出版社',@b); #out参数输出b的值

select @b; #查询用户变量b

#inout参数

#输入出版社名称,输出这个出版社出版的最贵的图书名称

delimiter //

create procedure p0004(INOUT c varchar(20)) -- inout参数

begin

declare cname varchar(20);

declare id varchar(10);

declare num int;

set cname=c;

set id=(select 出版社ID from 出版社信息 where 出版社名称=cname);

set c=(select 图书名称 from 图书信息 where 价格=(select max(价格) from 图书信息 where 出版社=id));

end //

delimiter ;

set @num='高等教育出版社'; #使用inout需提前赋值

call p0004(@num);

select @num;

#练习:创建存储过程,求1-m的累加和delimiter $$

delimiter //

create procedure p0005(IN m int)

begin

declare i int;

declare s int;

set i=0;

set s=0;

while i<m do

set i=i+1;

set s=s+i;

end while;

select s; #查询s的总值

end //

delimiter ;

call p0005(100);

#自定义函数

/*

delimiter //

create function <函数名称>(参数)

returns 自定义类型

deterministic begin

declare 参数名称 参数类型;

set 参数;

return 返回的参数;

end //

delimiter ;

select 函数名称(需要的参数);

*/

#例:

delimiter //

create function f1(a varchar(20))

returns varchar(30)

DETERMINISTIC begin

declare tname varchar(30);

set tname=(select 类型名称 from 商品类型 where 类型编号=a);

return tname;

end //

delimiter ;

select f1('t030102')

相关推荐
2301_803875613 分钟前
如何通过phpMyAdmin给WordPress所有用户发送全站通知_系统表插入
jvm·数据库·python
2301_7775993739 分钟前
mysql如何进行数据库容量规划_评估磁盘空间增长趋势
jvm·数据库·python
NineData1 小时前
NineData 亮相香港国际创科展 InnoEX 2026,以 AI 加速布局全球市场
运维·数据库·人工智能·ninedata·新闻资讯·玖章算术
m0_377618231 小时前
Redis怎样应对大规模集群的重启风暴_分批次重启节点并等待集群状态恢复绿灯后再继续操作
jvm·数据库·python
imuliuliang2 小时前
存储过程(SQL)
android·数据库·sql
考虑考虑2 小时前
SQL语句中的order by可能造成时间重复
数据库·后端·mysql
2401_835956812 小时前
Golang怎么写基准测试benchmark_Golang基准测试教程【完整】
jvm·数据库·python
阿杰学AI3 小时前
AI核心知识129—大语言模型之 向量数据库(简洁且通俗易懂版)
数据库·人工智能·ai·语言模型·自然语言处理·向量数据库·vector database
SPC的存折3 小时前
D在 Alpine 容器中手动搭建 Discuz 全攻略(包含镜像一键部署脚本,可直接用)
linux·数据库·mysql·缓存
李兆龙的博客3 小时前
从一到无穷大 #67 大查询根因分析 - 从 PinSQL 到 RCRank
数据库·时序数据库