MYSQL存储过程即常用逻辑知识点总结

Mysql存储过程

1.创建存储过程语法(格式)

DELIMITER $CREATE PROCEDURE 存储过程名A(IN 传入参数名a INT,IN 传入参数名b VARCHAR(20),OUT 返回参数名c INT)BEGIN  内容……….END $

解析:

  • IN 代表传入的参数,定义传入参数名,并且后面跟上传入参数类型(INT,VARCHAR,DOUBLE,……..)
  • OUT 代表存储过程执行完返回的数据,定义参数名,并且后面跟上参数类型(INT,VARCHAR,DOUBLE,……..)
  • INOUT 代表既可以传入也可以返回 ,定义参数名,并且后面跟上参数类型(INT,VARCHAR,DOUBLE,……..)

2.存储过程内具体语法与逻辑

A.定义变量语法:

DECLARE 变量名a 参数类型(INT,VARCHAR(20),BOOLEAN,……..) [DEFAULT NULL];

注:可以在参数类型后面加 DEFAULT NULL; 来设置初始值。

B.变量赋值

方式1(直接对变量进行赋值):

SET 定义的变量a = NEW();

方式2(sql查询的结果直接赋值给变量):

SELECT `student`.age INTO 定义的变量a FROM `student` WHERE………..

方式3(sql查询的结果直接赋值给多个变量):

SELECT `student`.name AS 定义的变量a,`student`.age AS 定义的变量b INTO 定义的变量a,定义的变量b FROM `student` ……………

c.逻辑判断:

#IF判断:    IF 条件语句(3>5) THEN  条件为TRUE时执行………;   END IF;  #IF ELSE判断:   IF 条件(a>0) THEN    条件为(a>0)时执行……..;    ELSE IF 条件(a<0) THEN    条件为(a<0)时执行…….;    ELSE         其它执行…….;  END IF;

D.游标,(LOOP)循环:

#例.单游标循环:create procedure my_procedure() — 创建存储过程begin — 开始存储过程declare my_id varchar(32); — 自定义变量1declare my_name varchar(50); — 自定义变量2DECLARE done INT DEFAULT FALSE; — 自定义控制游标循环变量,默认falseDECLARE cur CURSOR FOR ( SELECT id, name FROM t_people );– 定义游标并输入结果集DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE; — 绑定控制变量到游标,游标循环结束自动转trueOPEN cur; — 打开游标 posLoop: LOOP — 开始循环体,myLoop为自定义循环名,结束循环时用到 FETCH cur into my_id, my_name;– 将游标当前读取行的数据顺序赋予自定义变量12    IF done THEN – – 判断是否继续循环      LEAVE posLoop; — 结束循环    END IF; — 自己要做的事情,在 sql 中直接使用自定义变量即可 UPDATE t_user SET c_name = my_name WHERE id = my_id and rtrim(ltrim(c_name)) = ”; — 左右去空格 COMMIT; — 提交事务 END LOOP posLoop; — 结束自定义循环体 CLOSE cur; — 关闭游标END; — 结束存储过程#例.多游标循环:create procedure my_procedure() — 创建存储过程begin — 开始存储过程declare my_id varchar(32); — 自定义变量1declare my_name varchar(50); — 自定义变量2DECLARE done INT DEFAULT FALSE; — 自定义控制游标循环变量,默认falseDECLARE cur_1 CURSOR FOR ( SELECT id, name FROM t_people ); — 定义游标并输入结果集DECLARE cur_2 CURSOR FOR ( SELECT id_2,name_2 FROM t_people_2); –定义游标并输入结果集DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE; — 绑定控制变量到游标,游标循环结束自动转trueOPEN cur_1; — 打开游标 posLoop: LOOP — 开始循环体,myLoop为自定义循环名,结束循环时用到 FETCH cur_1 into my_id, my_name; — 将游标当前读取行的数据顺序赋予自定义变量12    IF done THEN — 判断是否继续循环      LEAVE posLoop; — 结束循环    END IF; — 自己要做的事情,在 sql 中直接使用自定义变量即可 UPDATE ……….;  –自己要做的具体操作 END LOOP posLoop; — 结束自定义循环体 CLOSE cur_1; — 关闭游标  SET done = FALSE;  – 因为当第一个游标遍历完后其值被handler设置为TRUE了,如果不用set把它设置为 FALSE ,那么第二个游标就不会遍历了。(最好是在每个打开游标的操作前都用该语句,以确保游标能真正遍历)OPEN cur_2; — 打开游标 posLoop_2: LOOP — 开始循环体,myLoop为自定义循环名,结束循环时用到 FETCH cur_2 into my_id, my_name; — 将游标当前读取行的数据顺序赋予自定义变量12    IF done THEN — 判断是否继续循环      LEAVE posLoop_2; — 结束循环    END IF; — 自己要做的事情,在 sql 中直接使用自定义变量即可 INSERT ……….;   –自己要做的具体操作 END LOOP posLoop_2; — 结束自定义循环体 CLOSE cur_2; — 关闭游标END; — 结束存储过程

3.存储过程的调用

#调用没有返回值的存储过程CALL 存储过程名(参数…..);#调用有返回值的存储过程(获得返回值)CALL 存储过程名(@aaa);SELECT @aaa;

4.删除存储过程

DROP PROCEDURE 存储过程名;

5.注意事项

存储过程中的分号(;)很重要,尽量不要省略。

郑重声明:本文内容及图片均整理自互联网,不代表本站立场,版权归原作者所有,如有侵权请联系管理员(admin#wlmqw.com)删除。
(0)
用户投稿
上一篇 2022年6月18日
下一篇 2022年6月18日

相关推荐

  • 乾隆退位后举办千叟宴,三千余名老人参宴,宴会结束老人接连死亡

    前言 嘉庆元年,乾隆皇帝设宴邀请了三千多名老人。这三千人,不仅有皇亲国戚、八旗贵族还有来自各个民族的老人。 这次设宴,乾隆皇帝本想向世人彰显皇家威严,体现统治者的宽广胸怀,促进各民…

    2022年8月30日
  • 传奇服务端如何添加地图

    传奇服务端如何添加地图 1. 打开M200 地图文件,路径MirServerMir200Map 2.打开地图文件可以看到有好多的地图在里面,可以网上搜索下各个地图相对应的代码然后复…

    2022年7月31日
  • 初代ipone se 现在到底还能不能用?

    我是从 A15 反向升级到初代 SE 的,原因是最近极需添置一台新 Mac 来运行 Logic,故将手中的设备逐件清仓回血,最后也把魔抓伸向了还没捂热乎的 SE 3 ——最后这台 …

    2022年7月27日
  • 疑似 iQOO 10 Pro 详细配置参数曝光,首发 200W 有线闪充

    不出意外,iQOO 10 系列手机也将在 7 月正式亮相。而在今天,数码博主数码闲聊站也公开爆料了 iQOO 10 Pro 的详细配置。 该消息源指出,iQOO 10 Pro 处理…

    2022年7月1日
  • Controller层代码这么写,简洁又优雅

    一个优秀的Controller层逻辑 说到 Controller,相信大家都不陌生,它可以很方便地对外提供数据接口。它的定位,我认为是「不可或缺的配角」,说它不可或缺是因为无论是传…

    2022年8月4日
  • vivox90pro配置参数跑分详情 vivox90pro是什么屏幕

    vivox90pro参数配置详情怎么样?vivo手机在昨晚举行了X90系列发布会,有普通款、pro款以及pro+款三个版本,那么vivox90pro具体配置怎么样呢?下面就让小编为…

    2022年11月23日
  • python爬虫学习体会

    去年在新同事入职培训时,我代表部门讲到了数据收集及可视化汇报,中间展示了我的爬虫项目,一位新同事看到我的代码,有点触动,课后找我聊python的学习应用问题。 我觉得我们正好是两种…

    2022年6月20日
  • Spring Boot – 自定义Aspect打印请求日志

    通常我们自定义一个Aspect用于记录请求日志,方便问题排查。 主要记录了如下信息: 请求方法及请求地址 客户端IP地址 调用的控制器类及方法名 请求头信息 请求参数 处理耗时 代…

    2022年7月12日
  • 一个注解搞定,记录项目日志

    最近正在录制 TienChin 项目视频 采用 Spring Boot+Vue3 技术栈,里边会涉及到各种好玩的技术,小伙伴们来和我一起做一个完成率超 90% 的项目。 前段时间做…

    2022年6月18日
  • 实用至上!618买对不买贵,6000拿下海尔海信康佳等4款常用大家电

    作为一名家电爱好者,每年618都会尤其关注一些热销家电、品牌家电的价格变化,尽管自己不入手,也喜欢对家电做一些小笔记,今年618也不例外,在3-4月我就开始关注那些热销家电,包括口…

    2022年6月17日

联系我们

联系邮箱:admin#wlmqw.com
工作时间:周一至周五,10:30-18:30,节假日休息