MySQL的存储过程
创始人
2024-11-19 11:33:27
0

存储过程的概念:

为了完成特定功能的sql语句的集合,把定义号的sql集合在一个特定的sql的函数当中,每次执行调用函数即可,还可以实现传参的调用。

存储过程的语法:

delimiter $$

delimiter : 开始和结束的语法

$$:标志位,可以自定义,不要用汉字和数字以及特殊字符开头

create procedure +存储过程的名称 ()

begin

select * from 表名;

end $$

delimiter;

查看存储过程

show procedure  status  where db='库名'; ​ show procedure  status  like  '%存储过程的名称%';

存储过程的作用:

执行速度要比sql语句执行速度更块,执行效率也更高。

客户端可以随时调用发放,也可以随时修改。

可以对数据做任何操作。

存储过程传参:

in 传入参数,调用者向存储过程传入值

delimiter $$ create procedure test1 (in uname char(20) ) begin select * from info where name = uname; select * from info; end $$ delimiter;   call test1('小明'); #call 存储过程名(传参内容)   #数据清晰和指定数据入库。分析数据行为。

out 输出参数 存储过程向调用者传出值 可以是多个值

delimiter $$ create procedure test2(out num int) BEGIN set num=100; end $$ delimiter; call test2(@num) select @num; insert into info1 values (@num);

inout 输入输出 既可以表示存储过程向调用者传出,也可以表示用户向存储过程传入值。

delimiter $$ create procedure test3 (inout str varchar(10)) #定义了变量之后一定要定义数据类型是什么 BEGIN select str;#在存储过程当中引用变量无需加@ #显示输入字符 set str = concat(str,'_ky32'); #把字符串进行替换 select str; #加工之后的字符串 end $$ delimiter;   set @str='小明'; #先传参,在外部需要加上@ call test3(@str);   update info set name=@str where id = 1; #看一下加工后str的内容  

存储过程的控制语句:

delimiter $$ create procedure test4 (inout num int) BEGIN if num >=10 then set num=num-5; else set num=num*2; end if; #结束if语句的判断 select num; end $$ delimiter;   set @num=19;   call test5(@num);   update info set id = @num where score = 100; ————————————————                             

调用多个参数

调用多个参数:范围的方式匹配,完成传参写入表中

delimiter $$ create procedure test7(inout score  int, out grade varchar(255)) BEGIN if score between 85 and 100 THEN set grade='优秀'; elseif score  between 60 and 84 then  set grade='及格'; else set grade='不及格'; end if;   end $$ delimiter;  set @score=90; call test7(@score,@grade); insert into info2 values (1,@score,@grade);  

while:循环语句

delimiter $$ create procedure test8(out rescult int) BEGIN declare a int; declare i int; #在过程体当中声明变量 set a=10; set i=1; while i<=10 do set a=a+10; set i=i+1; #相当于i++ end while; set rescult =a; end $$ delimiter;   set @rescult=90;   call test8(@rescult);   select @rescult;                        

相关内容

热门资讯

经核实!陕麻圈内购破解辅助(辅... 经核实!陕麻圈内购破解辅助(辅助挂)原来是有挂(科技开挂辅助脚本)-哔哩哔哩在进入陕麻圈内购破解辅助...
在玩家背景下!打哈儿脚本(辅助... 在玩家背景下!打哈儿脚本(辅助挂)一直确实有挂(正版开挂辅助插件)-哔哩哔哩该软件可以轻松地帮助玩家...
随着!奇迹手游辅助(辅助挂)一... 随着!奇迹手游辅助(辅助挂)一贯是有挂(了解开挂辅助神器)-哔哩哔哩一、奇迹手游辅助软件透明挂的定义...
近日!九天大厅辅助器(辅助挂)... 近日!九天大厅辅助器(辅助挂)原来有挂(推荐开挂辅助软件)-哔哩哔哩1、打开软件启动之后找到中间准星...
针对!口袋上饶棋牌辅助(辅助挂... 针对!口袋上饶棋牌辅助(辅助挂)原来是有挂(必看开挂辅助插件)-哔哩哔哩1、每一步都需要思考,不同水...
近年来!朋友局app辅助器下载... 近年来!朋友局app辅助器下载(辅助挂)一直确实有挂(发现开挂辅助下载)-哔哩哔哩该软件可以轻松地帮...
据玩家消息!山西扣点点辅助下载... 据玩家消息!山西扣点点辅助下载(辅助挂)一贯真的有挂(教会开挂辅助脚本)-哔哩哔哩山西扣点点辅助下载...
事发当天!川南久久辅助(辅助挂... 事发当天!川南久久辅助(辅助挂)其实确实有挂(实测开挂辅助安装)-哔哩哔哩1)川南久久辅助辅助挂:进...
今天下午!四川熊猫辅助官网(辅... 今天下午!四川熊猫辅助官网(辅助挂)其实真的有挂(必看开挂辅助软件)-哔哩哔哩1、玩家可以在四川熊猫...
此事引发网友热议!潮友会app... 此事引发网友热议!潮友会app下载安卓辅助软件(辅助挂)一直真的有挂(推荐开挂辅助插件)-哔哩哔哩1...