Mysql 存储过程中使用游标循环读取临时表
作者:傅小灰 发布时间:2024-01-28 00:55:20
游标
游标(Cursor)是用于查看或者处理结果集中的数据的一种方法。游标提供了在结果集中一次一行或者多行前进或向后浏览数据的能力。
游标的使用方式
定义游标:Declare 游标名称 CURSOR for table;(table也可以是select出来的结果集)
打开游标:Open 游标名称;
从结果集获取数据到变量:fetch 游标名称 into field1,field2;
执行语句:执行需要处理数据的语句
关闭游标:Close 游标名称;
BEGIN
# 声明自定义变量
declare c_stgId int;
declare c_stgName varchar(50);
# 声明游标结束变量
declare done INT DEFAULT 0;
# 声明游标 cr 以及游标读取到结果集最后的处理方式
declare cr cursor for select Name,StgId from StgSummary limit 3;
declare continue handler for not found set done = 1;
# 打开游标
open cr;
# 循环
readLoop:LOOP
# 获取游标中值并赋值给变量
fetch cr into c_stgName,c_stgId;
# 判断游标是否到底,若到底则退出游标
# 需要注意这个判断
IF done = 1 THEN
LEAVE readLoop;
END IF;
SELECT c_stgName,c_stgId;
END LOOP readLoop;
-- 关闭游标
close cr;
END
声明变量Declare语句注意点:
Declare语句通常用来声明本地变量、游标、条件或者handler
Declare语句只允许出现在BEGIN...END语句中而且必须出现在第一行
Declare的顺序也有要求,通常是先声明本地变量,再是游标,然后是条件和handler
自定义变量命名注意点:
自定义变量的名称不要和游标的结果集字段名一样。若相同会出现游标给变量赋值无效的情况。
临时表
临时表只在当前连接可见,当关闭连接时,Mysql会自动删除表并释放所有空间。因此在不同的连接中可以创建同名的临时表,并且操作属于本连接的临时表。
与普通创建语句的区别就是使用 TEMPORARY 关键字
CREATE TEMPORARY TABLE StgSummary(
Name VARCHAR(50) NOT NULL,
StgId INT NOT NULL DEFAULT 0
);
临时表使用限制
在同一个query语句中,只能查找一次临时表。同样在一个存储过程中也不能多次查询临时表。但是不同的临时表可以在一个query中使用。
不能用RENAME来重命名一个临时表,但是可以用ALTER TABLE代替
ALTER TABLE orig_name RENAME new_name;
临时表使用完以后需要主动Drop掉
DROP TEMPORARY TABLE IF EXISTS StgTempTable;
存储过程中使用游标循环读取临时表数据
BEGIN
## 创建临时表
CREATE TEMPORARY TABLE if not exists StgSummary(
Name VARCHAR(50) NOT NULL,
StgId INT NOT NULL DEFAULT 0
);
TRUNCATE TABLE StgSummary;
## 新增临时表数据
INSERT INTO StgSummary(Name,StgId)
select '临时数据',1
BEGIN
# 自定义变量
declare c_stgId int;
declare c_stgName varchar(50);
declare done INT DEFAULT 0;
declare cr cursor for select Name,StgId from StgSummary ORDER BY StgId desc LIMIT 3;
declare continue handler for not found set done = 1;
-- 打开游标
open cr;
testLoop:LOOP
-- 获取结果
fetch cr into c_stgName,c_stgId;
IF done = 1 THEN
LEAVE testLoop;
END IF;
SELECT c_stgName,c_stgId;
END LOOP testLoop;
-- 关闭游标
close cr;
End;
DROP TEMPORARY TABLE IF EXISTS StgSummary;
End;
最开始的时候,先创建临时表,再定义游标。但是存储过程无论如何都保存不了。直接报错You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'DECLARE ...
根本原因就是上面提到的注意点(Declare语句只允许出现在BEGIN...END
语句中而且必须出现在第一行)。所以最后只能多个加一对BEGIN...END
进行隔开。
总结
以前写SQL Server的存储过程,没有仔细注意过这个问题,定义变量一般都在程序中部,MySQL就想当然的随便写,最后终于踩坑了。这两个语法上差别不大,但是真遇到差别还是挺突然的。不过也好久没有写SQL语句,有点生疏了啊。还是赶紧把坑给记下来,加深下印象吧。
来源:https://www.cnblogs.com/cplemom/p/13970619.html
猜你喜欢
- Keras提供了一些用ImageNet训练过的模型:Xception,VGG16,VGG19,ResNet50,InceptionV3。在使
- 使用pycharm创建新项目,使用虚拟环境,但是进入到项目的cainiao_guoguo_health\venv\Scripts目录启动虚拟
- 1.聚合运算(1)使用内置的聚合运算函数进行计算1>内置的聚合运算函数sum(),mean(),max(),min(),size(),
- Pandas是Python中最流行的数据分析和处理工具之一,它提供了一个名为DataFrame的数据结构,可以被认为是一个二维表格或电子表格
- 1.OpenCV下载 首先创建一个空的文件夹,进入文件夹执行如下命令,如我创建的文件夹是opencv-pythoncd opencv-pyt
- 引言在观察OpenCV中某个函数在不同参数的情况下,所得到的效果的时候,我之前是改一次参数运行一次,这样做起来操作麻烦,效率低下。为了更便捷
- 前段时间在论坛上有人问到一个淘宝网上的hover伪类实现的效果如果兼容ie6。其实,问题很简单,就是hover伪类在IE6中得不到很好的支持
- WEB开发,我们先从搭建一个简单的服务器开始,Python自带服务模块,且python3相比于python2有很大不同,在Python2.6
- 摘要:NumPy中包含大量的函数,这些函数的设计初衷是能更方便地使用,掌握解这些函数,可以提升自己的工作效率。这些函数包括数组元素的选取和多
- 如何用数据库制作一个多用户版的计数器?代码和说明如下:count.asp' 计数器的核心程序<%Set c
- 任务1、 Mini计算器看出来错误了吗,哈哈哈哈哈哈,那三个点自己加的,本质应该是函数折叠完整的代码:ef calc(a,b,op):? ?
- #mkdir /mysqldata2、创建/usr/sbin/bakmysql文件#nano /usr/sbin/bakmysql输入:#!
- K线图概念股市及期货市bai场中的K线图的du画法包含四个zhi数据,即开盘dao价、最高价、最低价zhuan、收盘价,所有的shuk线都是
- PDO::beginTransactionPDO::beginTransaction 启动一个事务(PHP 5 >= 5.1.0, P
- 由于工作的需求,需要用python做一个类似网络爬虫的采集器。虽然Python的urllib模块提供更加方便简洁操作,但是涉及到一些底层的需
- 一、概述AutoEncoder大致是一个将数据的高维特征进行压缩降维编码,再经过相反的解码过程的一种学习方法。学习过程中通过解码得到的最终结
- 一、wordcloud库是什么?Python的wordcloud库是一个用于生成词云的Python包。它可以将一段文本中出现频率高的单词按其
- 一个小问题今天在做一个实验时,需要对一个包含中英文词汇的TXT文件进行读入和整理。Python代码的编码规则为UTF-8。在读入时,文件的每
- 环境:numpy,pandas,python3在机器学习和深度学习的过程中,对于处理预测,回归问题,有时候变量是时间,需要进行合适的转换处理
- 变量不是盒子在示例所示的交互式控制台中,无法使用“变量是盒子”做解释。图说明了在 Python 中为什么不能使用盒子比喻,而便利贴则指出了变