Mysql:存储过程练习

create table stu(

id int(3) primary key auto_increment,

name varchar(20) not null,

grade float,

gender char(2));

insert into stu(name,grade,gender) values('tom',60,'男'),('jack',70,'男'),('rose',90,'女'),('lucy',100,'女');

select * from stu;

#1.创建一个不带参数的存储过程p1并调用,功能:查询stu表中所有男生的信息。

drop procedure if exists p1;

delimiter //

create procedure p1()

begin

SELECT * FROM stu WHERE gender = '男';

end //

delimiter ;

call p1();

#2.创建一个带参数的存储过程p2并调用。功能:根据二个学生的学号从数据表中获取他们的grade数据并进行比较,并返回比较的结果(用二个输入参数,一个输出参数)。

drop procedure if exists p2;

delimiter //

create procedure p2(in id1 int(3),in id2 int(3),out num varchar(10))

begin

declare grade1 float;

declare grade2 float;

select grade into grade1 from stu where id=id1;

select grade into grade2 from stu where id=id2;

if grade1>grade2 then

set num='大于';

elseif grade1=grade2 then

set num='相等';

else

set num='小于';

end if;

end //

delimiter ;

call p2(1,2,@num);

select @num;

#3. 创建一个交换二个整数的存储过程p3并调用(用二个INOUT参数存放交换的二个数)。

drop procedure if exists p3;

delimiter //

create procedure p3(inout num1 int,inout num2 int)

begin

declare temp int;

set temp=num1;

set num1=num2;

set num2=temp;

end //

delimiter ;

set @num1=19;

set @num2=20;

call p3(@num1,@num2);

select @num1,@num2;

相关推荐
爱可生开源社区12 小时前
医疗业务系统升级,这家三甲医院为何牵手 OceanBase?(SQLServer->OceanBase)
数据库
huihuihuanhuan.xin12 小时前
后端八股之mysql
数据库·mysql
洋不写bug12 小时前
数据库数据类型,数据值类型,字符串类型,日期类型详解
数据库·mysql
Paraverse_徐志斌13 小时前
RAG架构(检索增强生成)与向量数据库
数据库·ai·llm·embedding·milvus·rag
NineData14 小时前
NineData将亮相第27届GOPS全球运维大会,并带来技术演讲
运维·数据库·ninedata·智能·ai agent·数据管理工具·gops全球运维大会
Java水解14 小时前
MySQL 中 ROW_NUMBER() 函数详解
后端·mysql
不良人天码星14 小时前
谈谈redis的持久化
数据库·redis·缓存
qq_4798754315 小时前
TimerFd & Epoll
java·服务器·数据库
绵绵细雨中的乡音15 小时前
MySQL 数据库核心操作全解析:从创建到备份与连接管理
数据库·oracle
wayuncn17 小时前
哈尔滨电商企业服务器托管方案
运维·服务器·数据库