`

解决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;
分享到:
评论

相关推荐

    sql总结.doc

    游标允许应用程序对查询语句select 返回的行结果集中每一行进行相同或不同的操作,而不是一次对整个结果集进行同一种操作; 它还提供对基于游标位置而对表中数据进行删除或更新的能力 缺点: 处理大数据量时,效率...

    100道mysql面试题.docx

    主键是表中的一列或一组列,用于唯一标识表中的每一行。 5. 什么是外键? 外键是表中的一列,用于建立与其他表的关联。 6. 什么是索引? 索引是一种数据结构,用于加快数据库的查询速度。 7. 什么是事务? 事务是...

    PHP和MySQL Web开发第4版pdf以及源码

    2.7.3 每次读取一行数据:fgets()、fgetss()和fgetcsv() 2.7.4 读取整个文件:readfile()、fpassthru()和file() 2.7.5 读取一个字符:fgetc() 2.7.6 读取任意长度:fread() 2.8 使用其他有用的文件函数 2.8.1 ...

    PHP和MySQL WEB开发(第4版)

    2.7.3 每次读取一行数据:fgets()、fgetss()和fgetcsv() 2.7.4 读取整个文件:readfile()、fpassthru()和file() 2.7.5 读取一个字符:fgetc() 2.7.6 读取任意长度:fread() 2.8 使用其他有用的文件函数 2.8.1 查看...

    PHP和MySQL Web开发第4版

    2.7.3 每次读取一行数据:fgets()、fgetss()和fgetcsv() 2.7.4 读取整个文件:readfile()、fpassthru()和file() 2.7.5 读取一个字符:fgetc() 2.7.6 读取任意长度:fread() 2.8 使用其他有用的文件函数 2.8.1 ...

    mysql数据库的基本操作语法

    MySQL会给唯一约束的列上默认创建一个唯一索引; create table temp ( id int not null, name varchar(25), password varchar(16), --使用表级约束语法, constraint uk_name_pwd unique(name, password) ); 表示...

    SQL必知必会(第3版)--详细书签版

    在 符号后输入的所有字符都应该是前一行的内容。  说明:给出上下文讨论中比较重要的信息。    提示:为某任务给出建议或一种更简单的方法。    注意:提醒可能出现的问题,避免出现事故。    新术语,提供新...

    Java面试宝典2020修订版V1.0.1.doc

    43、删除重复数据只保留一条。 55 44、一个几千万数据,发现数据查询很慢,怎么办? 55 六、Java高级部分 56 1、java中有几种方法可以实现一个线程?用什么关键字修饰同步方法? stop()和suspend()方法为何不推荐使用...

    SQL培训第一期

    记录,也被成为一行数据,是表里的每一行 1.4 完整性的约束条件 1.4.1 实体完整性 关系模型的实体完整性在create table中用primary key约束实现,primary key约束用于定义主键,它保证主键的唯一性和非空性。 1.4.2 ...

    Linux操作系统基础教程

    我在讲义的最后面附有 GPL 的 非官方中文译稿。目前 Linux 中国的发行版本(Linux Distribution)主要有 Red Hat (红帽子) , Slackware, Caldera, Debian, Red Flag (红旗) , Blue Point (蓝点) , Xteam ...

    Python Cookbook

    7.15 打印数据库游标的内容 304 7.16 适用于各种DB API模块的单参数传递风格 306 7.17 通过ADO使用Microsoft Jet 308 7.18 从Jython Servlet访问JDBC数据库 310 7.19 通过Jython和ODBC获得Excel数据 313 第8章...

    oracle学习文档 笔记 全面 深刻 详细 通俗易懂 doc word格式 清晰 连接字符串

    3. 运行该批处理程序将自动完成oracle卸载工作,最后手动删除\app文件夹(可能需要重启才能删除) 4. 运行regedit命令,打开注册表窗口。删除注册表中与Oracle相关的内容,具体如下:  删除HKEY_LOCAL_MACHINE/...

    SQL必知必会(第3版-PDF清晰版)part1

    重复的行..... 92 14.2.4 对组合查询 结果排序..... 93 14.3 小结..... 94 第15章 插入数据...... 95 15.1 数据插入..... 95 15.1.1 插入完整的行..... 95 15.1.2 插入部分行..... 98 15.1.3 插入检索出 的数据.......

Global site tag (gtag.js) - Google Analytics