MYSQL存储过程即常用逻辑知识点总结
作者:MoMing 发布时间:2024-01-21 07:36:36
标签: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); -- 自定义变量1
declare my_name varchar(50); -- 自定义变量2
DECLARE done INT DEFAULT FALSE; -- 自定义控制游标循环变量,默认false
DECLARE cur CURSOR FOR ( SELECT id, name FROM t_people ); -- 定义游标并输入结果集
DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE; -- 绑定控制变量到游标,游标循环结束自动转true
OPEN 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); -- 自定义变量1
declare my_name varchar(50); -- 自定义变量2
DECLARE done INT DEFAULT FALSE; -- 自定义控制游标循环变量,默认false
DECLARE 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; -- 绑定控制变量到游标,游标循环结束自动转true
OPEN 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.注意事项
存储过程中的分号(;)很重要,尽量不要省略。
来源:https://www.cnblogs.com/Moming0/p/11428960.html


猜你喜欢
- 本文实例讲述了python清除字符串里非数字字符的方法。分享给大家供大家参考。具体如下:import re s = "how19
- 一个线上项目报的死锁,简要说明一下产生原因、处理方案和相关的一些点.1、背景这是一个类似数据分析的项目,数据完全通过LOAD DATA语句导
- 1.1.1 摘要 Join是关系型数据库系统的重要操作之一,SQL Server中包含的常用Join:内联接、外联接和交叉联接等。如果我们想
- 函数,对于人类来讲,能够发展到这个数学思维层次,是一个飞跃。可以说,它的提出,直接加快了现代科技和社会的发展,不论是现代的任何科技门类,乃至
- 一、给定一个日期值,求出此日期所在星期的星期一和星期天的日期数据 例如给定一个日期 2010-09-01,求出它所在星期的星期一是2010-
- <?php $monthoneday=date("Ym")."01"; $oneweekday
- 摆线最简单的旋轮线就是摆线,指圆在直线上滚动时,圆周上某定点的轨迹。设圆的半径为 r ,在x轴上滚动 x距离则意味着旋转了 x
- 前言大家都知道,英文的分词由于单词间是以空格进行分隔的,所以分词要相对的容易些,而中文就不同了,中文中一个句子的分隔就是以字为单位的了,而所
- Numpy支持大量的维度数组和矩阵运算,对数组运算提供了大量的数学函数库!Numpy比Python列表更具优势,其中一个优势便是速度。在对大
- 前言弹幕可以给观众一种“实时互动”的错觉,虽然不同弹幕的发送时间有所区别,但是其只会在视频 * 定的一
- Python 中主要有8种数据类型:number(数字)、string(字符串)、list(列表)、tuple(元组)、dict(字典)、s
- 前言Python用于处理文本数据绝对是个利器,极为简单的读取、分割、过滤、转换支持,使得开发者不需要考虑繁杂的流文件处理过程(相对于JAVA
- 首先,我用的mysql版本号是5.5.17的,最近遇到的问题是在eclipse中通过jdbc往数据库写中文数据的时候,在数据库中显示的是??
- 前言:本博客只是因为我正在上计算机图形学这门课,为了方便复习所写,所以内容的正确性不敢保证,各位观看之前请三思(欢迎大佬提出建议)为VS20
- 导语一直以来,中国象棋都是中华民族的一种象征,当然也是人们最为喜感的一种娱乐方式。在若干年前,人们都习惯于约上自己的棋友,来一种激战。可是,
- Python 是一门动态、面向对象语言。其最初就是作为一门面向对象语言设计的,并且在后期又加入了一些更高级的特性。除了语言本身的设计目的之外
- 本文实例讲述了Go语言接口用法。分享给大家供大家参考。具体分析如下:接口类型是由一组方法定义的集合。接口类型的值可以存放实现这些方法的任何值
- pycurl是功能强大的python的url包,是用c语言写的,速度很快,比urllib和httplib都快调用方法:import pycu
- 平方根,又叫二次方根,表示为〔√ ̄〕,如:数学语言为:√ ̄16=4。语言描述为:根号下16=4。以下实例为通过用户输入一个数字,并计算这个数
- 前言使用 Python 的时候,我们知道 list 是一个长度可变对的数组, 可以通过 insert,append 和 extend 轻易的