MySQL中的游标

这篇具有很好参考价值的文章主要介绍了MySQL中的游标。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

什么是游标?

游标(cursor)是一个存储在MySQL服务器上的数据库查询, 它不是一条SELECT语句,而是被该语句检索出来的结果集。在存储了游 标之后,应用程序可以根据需要滚动或浏览其中的数据。

注意:MySQL游标只能用于 存储过程(和函数)。

创建游标

在创建一个游标前,我们需要先清除游标的语法

1、定义游标

DECLARE 游标名称 CURSOR FOR SQL语句;

2、打开游标

OPEN 游标名称;

3、获取结果

FETCH 游标名称 INTO 变量名称[,变量名称];

4、关闭游标

CLOSE 游标名称;

我们以Customers表来作为示例

mysql 游标,自动化测试,程序员,程序人生,单元测试,自动化测试,职场和发展,软件测试,mysql

示例一 

定义一个存储过程,调用的时候执行里面的游标

CREATE PROCEDURE PROC1()
BEGIN
    -- 定义两个存放结果的变量
    DECLARE NAME VARCHAR(20);
    DECLARE ADDR VARCHAR(50);
    -- 声明游标
    DECLARE MY CURSOR FOR SELECT 姓名,地址 FROM customers;
    -- 打开游标
    OPEN MY;
    -- 获取结果
    FETCH MY INTO NAME,ADDR;
    -- 这里是为了显示获取结果
    SELECT NAME,ADDR;
    -- 关闭游标
    CLOSE MY;    
END;

我们执行完上面的存储过程后,就可以调用该存储过程了

CALL PROC1();

得到结果:

mysql 游标,自动化测试,程序员,程序人生,单元测试,自动化测试,职场和发展,软件测试,mysql

这里肯定有小伙伴好奇,customers表里明明有7条记录,为什么只显示了1条记录?

这是因为游标的变量只保留了customers表中的第一行数据,如果要查看后面的数据,就需要循环往下移动游标,才能继续查看。

示例二

定义一个存储过程,调用存储过程时,将表customers里的数据循环写入新的表里面。

CREATE PROCEDURE PROC2()
BEGIN
    -- 定义两个存放结果的变量
    DECLARE FLAG INT DEFAULT 0; 
    DECLARE NAME VARCHAR(20);
    DECLARE ADDR VARCHAR(50);
    -- 声明游标
    DECLARE MY CURSOR FOR SELECT 姓名,地址 FROM customers;

    DECLARE CONTINUE HANDLER FOR NOT FOUND SET FLAG=1;
    -- 打开游标
    OPEN MY;
    -- 循环体部分
    L1:LOOP
    -- 获取结果
    FETCH MY INTO NAME,ADDR;
    IF FLAG=1 THEN
       LEAVE L1;
    END IF;
    -- 这里是为了显示获取结果
    INSERT INTO cus VALUES(NAME,ADDR);
    -- 关闭游标
    END LOOP;  -- 结束循环
    CLOSE MY;    
END;

然后我们执行这个存储过程,并查询cus表里的数据

CALL PROC2();
SELECT * FROM cus;

结果:

mysql 游标,自动化测试,程序员,程序人生,单元测试,自动化测试,职场和发展,软件测试,mysql

结果与customers里的一致,但是这些结果是循环一条一条往下移动的过程中插入的,即这个循环执行了7次。

以上就是游标的基本操作原理了,此外游标的循环体还有WHILE,REPEAT等操作方式,他们的操作方式与LOOP类似,都是用来循环执行循环体里面的内容,直到循环结束。

以上就是MySQL游标的相关内容,觉得不错记得帮忙转发+在看~

最后: 为了回馈铁杆粉丝们,我给大家整理了完整的软件测试视频学习教程,朋友们如果需要可以自行免费领取 【保证100%免费】

mysql 游标,自动化测试,程序员,程序人生,单元测试,自动化测试,职场和发展,软件测试,mysql

这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!

全套资料获取方式:

mysql 游标,自动化测试,程序员,程序人生,单元测试,自动化测试,职场和发展,软件测试,mysql

mysql 游标,自动化测试,程序员,程序人生,单元测试,自动化测试,职场和发展,软件测试,mysql文章来源地址https://www.toymoban.com/news/detail-730020.html

到了这里,关于MySQL中的游标的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 实战干货,pytest自动化测试-Git中的测试用例运行(详细)

    我们每天写完自动化用例后都会提交到 git 仓库,随着用例的增多,为了保证仓库代码的干净,当有用例新增的时候,我们希望只运行新增的未提交 git 仓库的用例。 pytest-picked 插件可以实现只运行未提交到git仓库的代码。 pytest-picked 使用命令行安装 可使用参数 使用示例:

    2024年02月09日
    浏览(61)
  • 精准备份:如何自动化单个MySQL数据库的备份过程

    自动化备份对于维护数据库的完整性和安全性至关重要。本指南将向您展示如何使用Shell脚本来自动化MySQL数据库的备份过程。 首先,这是我们将使用的备份脚本: 1. 保存脚本 将上面的脚本保存到服务器上,比如命名为 db_backup.sh : 粘贴脚本内容到编辑器中,然后保存并退出

    2024年04月11日
    浏览(47)
  • 爬虫实战(一)Python+selenium自动化获取数据存储到Mysql中

      行话说得好,“爬虫学得好,牢饭吃到饱!”哈哈博主是因这句话入的坑,不为别的就为邀大家一起铁窗泪(bushi),本人虽小牛一只,但是喜爱捣鼓技术,有兴趣的小伙伴们可以共同探讨,也欢迎各位大佬们的指点,愿共同进步!   这次计划是翻墙爬取外网某网站

    2024年01月17日
    浏览(48)
  • 【Ambari】HDP单机自动化安装(基础环境和MySQL脚本一键安装)

    🦄 个人主页 ——🎐开着拖拉机回家_Linux,大数据运维-CSDN博客 🎐✨🍁 🪁🍁🪁🍁🪁🍁🪁🍁 🪁🍁🪁🍁🪁🍁🪁 🪁🍁🪁🍁🪁🍁🪁🍁🪁🍁🪁🍁 感谢点赞和关注 ,每天进步一点点!加油! 目录 一、版本信息 1.1大数据组件版本 1.2Apache Components 1.3Databases支持版本

    2024年02月05日
    浏览(38)
  • MySQL中的游标

    游标(cursor)是一个存储在MySQL服务器上的数据库查询, 它不是一条SELECT语句,而是被该语句检索出来的结果集。在存储了游 标之后,应用程序可以根据需要滚动或浏览其中的数据。 注意:MySQL游标只能用于 存储过程(和函数)。 在创建一个游标前,我们需要先清除游标的

    2024年02月07日
    浏览(28)
  • python + Selenium 实现自动化查询问财数据及下载Excel数据并存入到mysql

    问财的数据海量及时,作为量化交易的数据来源也是一种不错的选择,之前也用过一些免费的api,但是数据不是很完整,时效性也不高,试了一下问财觉得很不错,不过下载有次数限制,非会员每天只能导出2次,会员每天200次。因为不想每天手工操作,所以想通过该方法实现

    2024年02月08日
    浏览(69)
  • 【云原生 | Docker】Linux 定时自动化备份Mysql数据到本地 & Windows 最佳实践,确定不来看看?

    🤵‍♂️ 个人主页: @AI_magician 📡主页地址: 作者简介:CSDN内容合伙人,全栈领域优质创作者。 👨‍💻景愿:旨在于能和更多的热爱计算机的伙伴一起成长!!🐱‍🏍 🙋‍♂️声明:本人目前大学就读于大二,研究兴趣方向人工智能硬件(虽然硬件还没开始玩,但一直

    2024年02月02日
    浏览(58)
  • 【项目案例】前后端分离项目 【中小企业办公自动化管理系统 】SpringBoot + Vue + Element UI + Mysql

    👉 博主介绍 : 博主从事应用安全和大数据领域,有8年研发经验,5年面试官经验,Java技术专家,WEB架构师,阿里云专家博主,华为云云享专家,51CTO 专家博主 Java知识图谱点击链接: 体系化学习Java(Java面试专题) 💕💕 感兴趣的同学可以收藏关注下 , 不然下次找不到哟

    2024年02月14日
    浏览(50)
  • Yaml版接口自动化详细讲解(Python + pytest + allure + log + yaml + mysql + redis + 钉钉通知 + Jenkins)

    目录 框架介绍 框架结构 框架功能讲解 common  # 配置         config.yaml  # 公共配置         setting.py  # 环境路径存放区域 data  # 测试用例数据 Files  # 上传文件接口所需的文件存放区域 logs  # 日志层 report  # 测试报告层 test_case  # 测试用例代码         __init

    2024年02月13日
    浏览(134)
  • 自动化测试系列 —— UI自动化测试

    UI 测试是一种测试类型,也称为用户界面测试,通过该测试,我们检查应用程序的界面是否工作正常或是否存在任何妨碍用户行为且不符合书面规格的 BUG。了解用户将如何在用户和网站之间进行交互以执行 UI 测试至关重要,通过执行 UI 测试,测试人员将尝试模仿用户的行为

    2024年02月10日
    浏览(50)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包