学习参考:
MySQL数据库 *实验17存储过程_数据库存储过程实验报告-CSDN博客
感觉就是相当于创建函数;
注意设置函数有一些特别的地方:
先直接来个例子:
创建这个存储过程标准格式大概如上 get_a_character是函数名字,drop procedure if exists是防止函数重复定义;
上面说过in/out/inout注意,因为相当于函数中的传参,out是函数内部的值,inout相当引用;
在内部填充代码,如果不是在函数名字声明的参数就要在内部进行声明才有效果,如果引用的是在sql内部设置过的@变量,可以直接使用@进行调用,至于在函数头设置的变量和函数内部使用declare设置的变量不加上@调用:
上面那题就如下的题解:
delimiter $$
drop procedure if exists get_word;
create procedure get_word(in s char(100),out w char(1))
Begin
declare len tinyint;
set len=char_length(s);
set w=substring(s,floor(rand()*(len+1)+1),1);
end $$
delimiter ;
再使用call进行调用,传入相应参数
有一个get_a_character的函数还要定义后面要用到
delimiter $$
drop procedure if exists get_a_character;
create procedure get_a_character(in s char(100),out w char(1))
begin
call get_word(s,w);
end $$
delimiter ;
set @x = '刘王张赵李钱朱何孙曾陈吴黄刘邓周毛江胡';
eg2:
delimiter $$
drop procedure if exists get_name;
create procedure get_name(out m varchar(2),out xb int)
begin
declare cd int;
declare ms1,ms2 varchar(50);
declare m1,m2,m3 varchar(2);
set ms1='依秋香巧紫萱莉玉碧丽念雅红燕艳莲荷蕾紫莹颖琪';
set ms2='澄德海超阳昌瀚亮锋涵煦杰俊诚毅峰衍浩广邈言博畅';
set xb = floor(rand()*2);
set cd = floor(rand()*2+1);
if xb = 0 then
call get_word(ms1,m1);
call get_word(ms1,m2);
set m3 = concat(m1,m2);
elseif xb = 1 then
call get_word(ms2,m1);
call get_word(ms2,m2);
set m3 = concat(m1,m2);
end if;
if cd = 1 then set m = m1;
elseif cd = 2 then set m = m3;
end if;
end $$
delimiter ;
eg3:
delimiter $$
drop procedure if exists main;
create procedure main()
begin
declare x varchar(100);
declare xing,ming,xm varchar(3);
declare sex,n int;
declare xh varchar(8)
create table xs2 as select 学号,姓名,性别 from xs where 1<>1 ;
set xh='191100';
set n=1;
while n<=20 do
call get_word(@x,@k);
set xing = @k;
call get_name(@name,@sex);
set ming = @name;
set sex = @sex;
set xm = concat(xing,ming);
insert into xs2 values(xh,xm,sex);
set n = n+1;
set xh = xh +1;
end while;
end $$
delimiter ;
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· winform 绘制太阳,地球,月球 运作规律
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人