mysql存储过程之游标(DECLARE)原理与用法详解
作者:luyaran 发布时间:2024-01-25 14:23:50
本文实例讲述了mysql存储过程之游标(DECLARE)原理与用法。分享给大家供大家参考,具体如下:
我们在处理存储过程中的结果集时,可以使用游标,因为游标允许我们迭代查询返回的一组行,并相应地处理每行。mysql的游标为只读,不可滚动和敏感三种模式,我们来看下:
只读:无法通过光标更新基础表中的数据。
不可滚动:只能按照select语句确定的顺序获取行。不能以相反的顺序获取行。 此外,不能跳过行或跳转到结果集中的特定行。
敏感:有两种游标:敏感游标和不敏感游标。敏感游标指向实际数据,不敏感游标使用数据的临时副本。敏感游标比一个不敏感的游标执行得更快,因为它不需要临时拷贝数据。但是,对其他连接的数据所做的任何更改都将影响由敏感游标使用的数据,因此,如果不更新敏感游标所使用的数据,则更安全。 MySQL游标是敏感的。
我们可以在存储过程,存储函数和触发器中使用MySQL游标,咱们先来看下使用DECLARE语句声明的语法:
DECLARE cursor_name CURSOR FOR SELECT_statement;
我们要注意下,游标声明必须在变量声明之后。如果在变量声明之前声明游标,mysql将会发出一个错误,另外游标必须始终与SELECT语句相关联。完事呢,我们来使用OPEN语句打开游标。OPEN语句初始化游标的结果集,因此我们必须在从结果集中提取行之前调用OPEN语句:
OPEN cursor_name;
然后,我们来使用FETCH语句来检索光标指向的下一行,并将光标移动到结果集中的下一行:
FETCH cursor_name INTO variables list;
之后,我们就可以检查是否有任何行记录可用,然后再提取它。完事最后还要记得调用CLOSE语句来停用光标并释放与之关联的内存:
CLOSE cursor_name;
我们要知道,当光标不再使用时,应该关闭它。当我们使用mysql游标时,还必须声明一个NOT FOUND处理程序来处理当游标找不到任何行时的情况。 因为每次调用FETCH语句时,游标会尝试读取结果集中的下一行。 当光标到达结果集的末尾时,它将无法获得数据,并且会产生一个条件。NOT FOUND处理程序用于处理这种情况,我们来看下它的语法结构:
DECLARE CONTINUE HANDLER FOR NOT FOUND SET finished = 1;
finished是一个变量,指示光标到达结果集的结尾。请注意,处理程序声明必须出现在存储过程中的变量和游标声明之后。我们再来看下mysql游标的运行原理图:
咱们接下来,就要开发一个存储过程用来获取employees表中所有员工的电子邮件列表。我们先来声明一些变量,一个用于循环员工电子邮件的游标和一个NOT FOUND处理程序:
DECLARE finished INTEGER DEFAULT 0;
DECLARE email varchar(255) DEFAULT "";
-- declare cursor for employee email
DEClARE email_cursor CURSOR FOR
SELECT email FROM employees;
-- declare NOT FOUND handler
DECLARE CONTINUE HANDLER
FOR NOT FOUND SET finished = 1;
接下来,使用OPEN语句打开email_cursor:
OPEN email_cursor;
然后,迭代电子邮件列表,并使用分隔符(;)连接每个电子邮件:
get_email: LOOP
FETCH email_cursor INTO v_email;
IF v_finished = 1 THEN
LEAVE get_email;
END IF;
-- build email list
SET email_list = CONCAT(v_email,";",email_list);
END LOOP get_email;
之后,我们在循环中,使用v_finished变量来检查列表中是否有任何电子邮件来终止循环,完事呢,使用CLOSE语句关闭游标:
CLOSE email_cursor;
我们来看下build_email_list存储过程所有代码:
DELIMITER $$
CREATE PROCEDURE build_email_list (INOUT email_list varchar(4000))
BEGIN
DECLARE v_finished INTEGER DEFAULT 0;
DECLARE v_email varchar(100) DEFAULT "";
-- declare cursor for employee email
DEClARE email_cursor CURSOR FOR
SELECT email FROM employees;
-- declare NOT FOUND handler
DECLARE CONTINUE HANDLER
FOR NOT FOUND SET v_finished = 1;
OPEN email_cursor;
get_email: LOOP
FETCH email_cursor INTO v_email;
IF v_finished = 1 THEN
LEAVE get_email;
END IF;
-- build email list
SET email_list = CONCAT(v_email,";",email_list);
END LOOP get_email;
CLOSE email_cursor;
END$$
DELIMITER ;
我们来使用以下脚本测试build_email_list存储过程:
SET @email_list = "";
CALL build_email_list(@email_list);
SELECT @email_list;
至于结果,咱就不赘述了哈。
希望本文所述对大家MySQL数据库计有所帮助。
来源:https://blog.csdn.net/luyaran/article/details/80969807
猜你喜欢
- 目的:把question_id 对应的user_answer转成ABCDsolutiondfa=df.groupby('questi
- #!/usr/bin/python# -*- coding: utf-8 -*-from scapy.all import *from ti
- 本文实例讲述了python计算N天之后日期的方法。分享给大家供大家参考。具体如下:python计算N天之后的日期,可以自己写成一个函数,想得
- 在不使用matlab的情况下,可以选择用python来实现自动控制理论有关系统打时域分析和频率域分析等,安装的package是python-
- ADO.NET 连接到 SQL Server SQL Server .NET Framework 数据提供程序支持类似于 OLE DB (A
- 一直以来,jQuery是我最喜欢的框架之一。1月14号 1.4 Released版本发布后,就迫不及待去了解了一下1.4版本对比以往1.3.
- 简介概念散列算法(Hash Algorithm),又称哈希算法,杂凑算法,是一种从任意文件中创造小的数字「指纹」的方法。与指纹一样,散列算法
- 函数的返回值返回结果要怎么做,多个结果又要怎么做# 函数返回值# 概念:函数执行完以后会返回一个对象,如果在函数内部有return 就可以返
- 之前已经简单介绍了Python正则表达式的基础与捕获,那么在这一篇文章里,我将总结一下正则表达式的贪婪/非贪婪特性。 贪婪默认情况
- 本文实例讲述了python使用socket远程连接错误处理方法。分享给大家供大家参考。具体如下:import socket, syshost
- 这个教程,我们将展示如何用python创建一个井字游戏。 其中我们将使用函数、数组、if条件语句、while循环语句和错误捕获等
- 给定图像集如下,所有类别的图片均在一个文件夹内:给定与图片名相匹配的表格,声明每张图片对应的类别(共有20个类别):那么,如何根据表格中所给
- 前言在golang当中,defer代码块会在函数调用链表中增加一个函数调用。这个函数调用不是普通的函数调用,而是会在函数正常返回,也就是re
- 这是一个绘制矩阵的函数。用matshow绘制矩阵的例子:import matplotlib.pyplot as pltimport nump
- 简介这篇宏哥就带着小伙伴们分享一下如何连接模拟器(电脑版的虚拟手机),然后再安装一款APP-淘宝为例。一、appium+pycharm+连接
- 我就废话不多说了,直接上代码!from enum import Enumclass Values(): values={'
- OAuth2 的概念OAuth是一个关于授权的开放网络标准,OAuth2是其2.0版本。它规定了四种操作流程(授权模式)来确保安全应用场景有
- 本文实例讲述了php 多继承的几种常见实现方法。分享给大家供大家参考,具体如下:class Parent1 { function
- 如下所示:result = os.popen('ps aux') res = result.read()
- 数据类型计算机顾名思义就是可以做数学计算的机器,因此,计算机程序理所当然地可以处理各种数值。但是,计算机能处理的远不止数值,还可以处理文本、