学习参考:
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 ;

