热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

解决MySQL游标最后一行重复

在使用MySQL游标时,发现最后一行一直被重复读取后来在发现应该把读取到的数据放在下一个循环里面使用可以避免重复代码如下:

在使用MySQL游标时,发现最后一行一直被重复读取 后来在发现应该把读取到的数据放在下一个循环里面使用可以避免重复 代码如下:

Linux公社

首页 → 数据库技术

背景:

阅读新闻

解决MySQL 游标最后一行重复

[日期:2011-07-20] 来源:Linux社区 作者:babaoqi [字体:]

在使用MySQL游标时,发现最后一行一直被重复读取

后来在发现应该把读取到的数据放在下一个循环里面使用可以避免重复

代码如下:
DELIMITER $$

USE `test`$$

DROP PROCEDURE IF EXISTS `sp_getAllTableName`$$

CREATE PROCEDURE `sp_getAllTableName`(OUT strAllTableNames VARCHAR(10000))
BEGIN
DECLARE bEnd BOOLEAN DEFAULT FALSE;
DECLARE tbName VARCHAR(255);

# 声明游标
DECLARE curTableNames CURSOR FOR SELECT TABLE_NAME FROM information_schema.tables AS t WHERE t.table_schema="test";

# DECLARE CONTINUE HANDLER
DECLARE CONTINUE HANDLER FOR SQLSTATE '02000' SET bEnd=TRUE;

SET strAllTableNames = "";

# 打开游标
OPEN curTableNames;

# 获取所有行数据
# 获取第一行内容
FETCH curTableNames INTO tbName;

# 循环开始
REPEAT
SET strAllTableNames = CONCAT(strAllTableNames,tbName,";");
# 获取下一行内容
FETCH curTableNames INTO tbName;
# 循环结束
UNTIL bEnd END REPEAT;

# 关闭游标
CLOSE curTableNames;

# 处理完毕
SET strAllTableNames = CONCAT("All table names:",strAllTableNames);

END$$

DELIMITER ;

CALL test.sp_getAllTableName(@allNames);

SELECT @allNames;

linux

  • 0
  • 设置CentOS下开机自动启动Oracle

    Oracle Shared Pool优化思路

    相关资讯 MySQL教程

    图片资讯

    本文评论   查看全部评论 (0)

    评论声明

    最新资讯

    本周热门

    Linux公社简介 - 广告服务 - 网站地图 - 帮助信息 - 联系我们
    本站(LinuxIDC)所刊载文章不代表同意其说法或描述,仅为提供更多信息,也不构成任何建议。


    Copyright © 2006-2011 Linux公社 All rights reserved 浙ICP备06018118号


    推荐阅读
    • CentOS下ProFTPD的安装与配置指南
      本文详细介绍在CentOS操作系统上安装和配置ProFTPD服务的方法,包括基本配置、安全设置及高级功能的启用。 ... [详细]
    • 本文详细介绍了在 CentOS 系统中如何创建和管理 SWAP 分区,包括临时创建交换文件、永久性增加交换空间的方法,以及如何手动释放内存缓存。 ... [详细]
    • 软件测试行业深度解析:迈向高薪的必经之路
      本文深入探讨了软件测试行业的发展现状及未来趋势,旨在帮助有志于在该领域取得高薪的技术人员明确职业方向和发展路径。 ... [详细]
    • 如何处理PHP缺少扩展的问题
      本文将详细介绍如何解决PHP环境中缺少扩展的问题,包括检查当前环境、修改配置文件以及验证修改是否生效的具体步骤,帮助开发者更好地管理和使用PHP扩展。 ... [详细]
    • 本文回顾了作者在求职阿里和腾讯实习生过程中,从最初的迷茫到最后成功获得Offer的心路历程。文中不仅分享了个人的面试经历,还提供了宝贵的面试准备建议和技巧。 ... [详细]
    • 如何在Win10系统下通过VMware 14 Pro安装CentOS 7
      本文详细介绍了在Windows 10操作系统中使用VMware Workstation 14 Pro搭建CentOS 7虚拟环境的步骤,包括所需工具、安装过程及系统配置等。 ... [详细]
    • 在Android应用开发过程中,开发者经常遇到诸如CPU使用率过高、内存泄漏等问题。本文将介绍几种常用的命令及其应用场景,帮助开发者有效定位并解决问题。 ... [详细]
    • 在中标麒麟操作系统上部署达梦数据库及导入SQL文件
      本文档详细介绍了如何在中标麒麟操作系统上安装达梦数据库,并提供了导入SQL文件的具体步骤。首先,检查系统的发行版和内核版本,接着创建必要的用户和用户组,规划数据库安装路径,挂载安装介质,调整系统限制以确保数据库的正常运行,最后通过图形界面完成数据库的安装。 ... [详细]
    • 利用 Calcurse 在 Linux 终端高效管理日程与任务
      对于喜爱使用 Linux 终端进行日常操作的系统管理员来说,Calcurse 提供了一种强大的方式来管理日程安排、待办事项及会议。本文将详细介绍如何在 Linux 上安装和使用 Calcurse,帮助用户更有效地组织工作。 ... [详细]
    • 本文介绍了SELinux的两种主要工作模式——强制模式和宽容模式,并提供了如何在CentOS 7中正确启用和配置SELinux的方法,以及在遇到登录问题时的解决策略。 ... [详细]
    • 龙蜥社区开发者访谈:技术生涯的三次蜕变 | 第3期
      龙蜥社区的开发者们通过自己的实践和经验,推动着开源技术的发展。本期「龙蜥开发者说」聚焦于一位资深开发者的三次技术转型,分享他在龙蜥社区的成长故事。 ... [详细]
    • 本文介绍了Linux操作系统的核心组成部分——内核及其版本分类,以及市面上常见的几种Linux发行版,旨在为初学者提供一个清晰的学习路径。 ... [详细]
    • 如何在Mozilla Firefox中调整GIF动画的循环次数
      本文介绍了如何通过调整Mozilla Firefox的高级设置来控制GIF动画的播放次数,帮助用户根据个人喜好自定义浏览体验。 ... [详细]
    • CentOS7通过RealVNC实现多人使用服务器桌面
      背景:公司研发团队通过VNC登录到CentOS服务器的桌面实现软件开发工作为防止数据外泄,需要在RealVNC设置禁止传输文件、访问粘贴板等策略过程&# ... [详细]
    • 本文详细介绍了如何在 CentOS 7 及其衍生发行版(如 Red Hat, Oracle, Scientific Linux 7)上安装和完全卸载 GitLab。包括安装必要的依赖关系、配置防火墙、安装 GitLab 软件包以及常见问题的解决方法。 ... [详细]
    author-avatar
    红太郎的等待_921
    这个家伙很懒,什么也没留下!
    PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
    Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有