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;

相关推荐
zfoo-framework4 分钟前
通过redis-cli+lua脚本查询redis数据
数据库·redis·lua
牛栓柱16 分钟前
【后端实战】用 Supabase + React/TS 零成本构建高并发 Multi-Agent 服务
前端·数据库·人工智能·后端·react.js·前端框架
yuezhilangniao19 分钟前
xtr备份prepare到底变化了啥
mysql
yyk的萌21 分钟前
创建属于自己的mysql的mcp
mysql·adb·ai·mcp
流烟默21 分钟前
腾讯云Centos7.6使用yum安装MySQL8
mysql·centos·腾讯云
仙俊红26 分钟前
如何优化 MySQL 深分页 SQL
android·sql·mysql
yyuuuzz1 小时前
谷歌云基础服务的入门认知
linux·运维·服务器·数据库·人工智能·github
超梦dasgg1 小时前
工作中 MySQL 读写分离主从延迟:成因、影响、落地方案、生产实战处理
数据库·mysql
Wonderful U1 小时前
Python+Django实战:打造智能生鲜果蔬进销存管理系统(采购入库、库存预警、销售开单、毛利统计)
数据库·python·django
Demon1_Coder1 小时前
Day4-微服务-Seata默认事务
java·数据库·微服务