Mysql存储过程
创始人
2024-11-12 17:34:18
0

一、存储过程

1、概念

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

2、作用

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

客户端可以随时调用发放,也可以随时修改,可以对数据库做任何操作,

3、语法

创建库和表

create database xy102;  create table info1 ( id int(2) primary key, name varchar(10), high int(3), address varchar(15) ); 

3.1 delimiter $$

delimiter是开始和结束语法,$$是标志位,可以自定义,不要用汉字或者数字开头,不能使用特殊字符开头

delimiter $$ create procedure test1 () begin  select * from info1; end $$ delimiter;  # 查看存储过程命令 1.1 show procedure status where db='xy102'; 1.2 show procedure status like '%test1%';  # 直接在表中编辑信息后,执行存储命令id=1,name=小戴,high=167,address=南京  # 执行存储过程命令 call test1;  delimiter $$ create procedure test2 () begin  select * from info1;  update info1 set high=180 where id = 1; end $$ delimiter;   call test2; 

3.2 存储过程传参

in 传入参数,调用者向存储过程传入值
out 输出参数,存储过程向调用者传出值,可以是多个值
inout 输入输出 既可以表示存储过程向调用者传出,也可以表示用户向存储过程传入值

delimiter $$ create procedure test3 (in uname char(20)) BEGIN  SELECT * from info1 where name = uname; END $$ delimiter;  # 直接在表中编辑信息后,执行存储命令id=2,name=小黄,high=172,address=南京  call test3 ('小黄'); # 显示信息为name=小黄的行 

3.3 输出参数

delimiter $$  create procedure test4( out id int, out name char(10), out high int, out address varchar(10)  )  begin  set id=3,name='王心凌',high=185,address ='幸云教育'; end $$ delimiter;  call test4(@id,@name,@high,@address) select @id,@name,@high,@address; insert into info1 values(@id,@name,@high,@address); 

3.4 输入输出参数

在存储过程当中存储过程是不需要加@的

delimiter $$  create procedure test7(inout str varchar(10)) begin select str; # 在存储过程当中存储过程是不需要加@的 set str=concat(str,'_xy102'); # 替换 把字符换成进行替换 select str; end $$ delimiter;  set @str='蔡依林'; call test7(@str);  update info1 set name=@str where id = 3;   # 把王心凌 high=185改成王心凌 high=195  delimiter $$  create procedure test8(inout ht varchar(10)) begin set ht=ht+10; end $$ delimiter;  set @ht=185; call test8(@ht);  update info1 set name=@ht where id = 3; 

3.5 存储过程的控制语句

delimiter $$  create procedure test9(inout num int) begin if num >=10 then set num=num-5; else set num=num*2; end if end $$ delimiter;  set @num=19  call test9(@num)  update info1 set id=@num where high =111;  

相关内容

热门资讯

方针辅助!纳祥游戏科技(辅助挂... 方针辅助!纳祥游戏科技(辅助挂)真是真的有辅助技巧(真的有挂)1、纳祥游戏科技透视辅助软件激活码多个...
诀窍辅助!潮汕汇鱼虾蟹辅助(辅... 诀窍辅助!潮汕汇鱼虾蟹辅助(辅助挂)好像存在有辅助攻略(真的有挂)1、在潮汕汇鱼虾蟹辅助插件功能辅助...
窍门辅助!洞庭茶苑app辅助(... 您好,洞庭茶苑app辅助这款游戏可以开挂的,确实是有挂的,需要了解加去威信【136704302】很多...
演示辅助!欢欢辅助软件怎么样(... 演示辅助!欢欢辅助软件怎么样(辅助挂)都是真的是有辅助技巧(有挂教程)1、欢欢辅助软件怎么样脚本辅助...
积累辅助!微信小程序里的微乐可... 积累辅助!微信小程序里的微乐可以开挂吗(辅助挂)总是确实有辅助教程(发现有挂)1、下载好微信小程序里...
课程辅助!功夫川麻辅助(辅助挂... 课程辅助!功夫川麻辅助(辅助挂)好像真的有辅助技巧(有挂秘笈)1、完成功夫川麻辅助有辅助插件,帮助玩...
方针辅助!顺欣茶楼开挂(辅助挂... 方针辅助!顺欣茶楼开挂(辅助挂)果然真的有辅助app(今日头条)1、顺欣茶楼开挂脚本辅助下载、顺欣茶...
步骤辅助!涂山山西辅助(辅助挂... 步骤辅助!涂山山西辅助(辅助挂)真是真的是有辅助插件(有挂总结)涂山山西辅助破解侠是真的助透视。每个...
讲义辅助!欢乐掌心辅助(辅助挂... 讲义辅助!欢乐掌心辅助(辅助挂)竟然确实有辅助神器(有挂细节)1、金币登录送、破产送、升级送、活动送...
大纲辅助!微信小程序加速器(辅... 大纲辅助!微信小程序加速器(辅助挂)确实是有辅助插件(有挂解密)大纲辅助!微信小程序加速器(辅助挂)...