iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >MySQL游标多循环一次的问题怎么解决
  • 634
分享到

MySQL游标多循环一次的问题怎么解决

2024-04-02 19:04:59 634人浏览 安东尼
摘要

这篇文章主要讲解了“Mysql游标多循环一次的问题怎么解决”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“mysql游标多循环一次的问题怎么解决”吧!

这篇文章主要讲解了“Mysql游标多循环一次的问题怎么解决”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“mysql游标多循环一次的问题怎么解决”吧!

在Mysql中使用游标的时候,发现游标多循环一次
想在表中插入一条语句,但是实际上却插入了两条
语句如下:
mysql> create table test(id int(5));
Query OK, 0 rows affected (0.13 sec)

mysql> delimiter $$
mysql> create procedure proc_drop_table()
    -> BEGIN
    ->
    -> DECLARE done_1 INT DEFAULT FALSE;
    -> DECLARE v_history_table_name varchar(64);
    -> declare the_query VARCHAR(500);
    ->
    ->
    -> DECLARE not_found CONDITioN FOR 1741;
    ->
    ->
    -> DECLARE cur1 CURSOR FOR select CONCAT(TABLE_SCHEMA,'.',TABLE_NAME) from  infORMation_schema.tables where TABLE_SCHEMA='test' and TABLE_NAME like '%test%';
    ->
    ->
    ->
    -> DECLARE CONTINUE HANDLER FOR NOT FOUND SET done_1 = TRUE;
    ->
    ->     OPEN cur1;
    ->     read_loop_1: LOOP
    ->     FETCH cur1 INTO v_history_table_name;
    ->
    -> set @v_history_table_name=v_history_table_name;
    ->     select concat('insert into ', @v_history_table_name, ' values (10)') into the_query;
    -> SET @stmt=the_query;
    -> PREPARE STMT FROM @stmt;
    -> EXECUTE STMT;
    -> DEALLOCATE PREPARE STMT;
    ->
    ->     IF done_1 THEN
    ->     LEAVE read_loop_1;
    -> END IF;
    -> END LOOP read_loop_1;
    -> CLOSE cur1;
    ->     end$$
Query OK, 0 rows affected (0.01 sec)

mysql> delimiter ;
mysql> select * from test;
Empty set (0.00 sec)

mysql> call proc_drop_table();
Query OK, 0 rows affected (0.01 sec)

mysql> select * from test;
+------+
| id   |
+------+
|   10 |
|   10 |
+------+
2 rows in set (0.00 sec)

解决方法:
在实际执行的语句两边增加IF判断

mysql> truncate table test;
Query OK, 0 rows affected (0.07 sec)

mysql> drop procedure proc_drop_table;
Query OK, 0 rows affected (0.09 sec)

mysql> delimiter $$
mysql> create procedure proc_drop_table()
    -> BEGIN
    ->
    -> DECLARE done_1 INT DEFAULT FALSE;
    -> DECLARE v_history_table_name varchar(64);
    -> declare the_query VARCHAR(500);
    ->
    ->
    -> DECLARE not_found CONDITION FOR 1741;
    ->
    ->
    -> DECLARE cur1 CURSOR FOR select CONCAT(TABLE_SCHEMA,'.',TABLE_NAME) from  information_schema.tables where TABLE_SCHEMA='test' and TABLE_NAME like '%test%';
    ->
    ->
    ->
    -> DECLARE CONTINUE HANDLER FOR NOT FOUND SET done_1 = TRUE;
    ->
    ->     OPEN cur1;
    ->     read_loop_1: LOOP
    ->     FETCH cur1 INTO v_history_table_name;
    -> IF done_1 IS FALSE THEN
    -> set @v_history_table_name=v_history_table_name;
    ->     select concat('insert into ', @v_history_table_name, ' values (10)') into the_query;
    -> SET @stmt=the_query;
    -> PREPARE STMT FROM @stmt;
    -> EXECUTE STMT;
    -> DEALLOCATE PREPARE STMT;
    -> END IF;
    ->     IF done_1 THEN
    ->     LEAVE read_loop_1;
    -> END IF;
    -> END LOOP read_loop_1;
    -> CLOSE cur1;
    ->     end$$
Query OK, 0 rows affected (0.00 sec)

mysql> delimiter ;
mysql> call proc_drop_table();
Query OK, 0 rows affected (0.01 sec)

mysql> select * from test;
+------+
| id   |
+------+
|   10 |
+------+
1 row in set (0.00 sec)

感谢各位的阅读,以上就是“MySQL游标多循环一次的问题怎么解决”的内容了,经过本文的学习后,相信大家对MySQL游标多循环一次的问题怎么解决这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

您可能感兴趣的文档:

--结束END--

本文标题: MySQL游标多循环一次的问题怎么解决

本文链接: https://www.lsjlt.com/news/59053.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • MySQL游标多循环一次的问题怎么解决
    这篇文章主要讲解了“MySQL游标多循环一次的问题怎么解决”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MySQL游标多循环一次的问题怎么解决”吧! ...
    99+
    2022-10-18
  • java for循环内执行多线程问题怎么解决
    这篇文章主要介绍了java for循环内执行多线程问题怎么解决的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇java for循环内执行多线程问题怎么解决文章都会有所收获,下面我们一起来看看吧...
    99+
    2023-07-05
  • Java循环内的回调函数问题怎么解决
    本篇内容介绍了“Java循环内的回调函数问题怎么解决”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!问题出现在循环体内的回调函数,用一个很简单...
    99+
    2023-06-04
  • Java中Map循环遍历的效率问题怎么解决
    在Java中,Map的循环遍历可以通过使用不同的方法来提高效率:1. 使用entrySet()方法遍历:遍历Map的entrySet...
    99+
    2023-08-15
    Java Map
  • Javascript深度克隆中的循环引用问题怎么解决
    这篇文章主要介绍“Javascript深度克隆中的循环引用问题怎么解决”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Javascript深度克隆中的循环引用问题怎么...
    99+
    2022-10-19
  • 使用JSON.stringify时遇到的循环引用问题怎么解决
    这篇文章给大家分享的是有关使用JSON.stringify时遇到的循环引用问题怎么解决的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。程序员在日常做TypeScript/JavaScript开发时,经常需要将复杂的...
    99+
    2023-06-14
  • 怎么解决React useEffect钩子带来的无限循环问题
    本篇内容主要讲解“怎么解决React useEffect钩子带来的无限循环问题”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么解决React useEffect钩子带来的无...
    99+
    2023-07-02
  • vue项目中created()被调用多次的问题怎么解决
    本文小编为大家详细介绍“vue项目中created()被调用多次的问题怎么解决”,内容详细,步骤清晰,细节处理妥当,希望这篇“vue项目中created()被调用多次的问题怎么解决”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来...
    99+
    2023-07-05
  • spring bean的自动注入及循环依赖问题怎么解决
    这篇文章主要介绍了spring bean的自动注入及循环依赖问题怎么解决的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇spring bean的自动注入及循环依赖问题怎么解决文章都会有所收获,下面我们一起来看看吧...
    99+
    2023-07-05
  • Spring处理@Async导致的循环依赖失败问题怎么解决
    本文小编为大家详细介绍“Spring处理@Async导致的循环依赖失败问题怎么解决”,内容详细,步骤清晰,细节处理妥当,希望这篇“Spring处理@Async导致的循环依赖失败问题怎么解决”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入...
    99+
    2023-07-02
  • 怎么解决RestTemplate第一次请求响应速度较慢的问题
    本篇内容主要讲解“怎么解决RestTemplate第一次请求响应速度较慢的问题”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么解决RestTemplate第一次请求响应速度较慢的问题”吧!Re...
    99+
    2023-06-25
  • MySQL和Redis的数据一致性问题怎么解决
    本篇内容主要讲解“MySQL和Redis的数据一致性问题怎么解决”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“MySQL和Redis的数据一致性问题怎么解决”吧!前言:在数据读多写少的情况下作为...
    99+
    2023-06-29
  • Redis与MySQL的双写一致性问题怎么解决
    本篇内容介绍了“Redis与MySQL的双写一致性问题怎么解决”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!Redis与MySQL双写一致性...
    99+
    2023-07-05
  • Mybatis对sql表的一对多查询问题怎么解决
    这篇“Mybatis对sql表的一对多查询问题怎么解决”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Mybatis对sql表...
    99+
    2023-07-02
  • mybatis一对一查询一对多查询遇到的问题怎么解决
    这篇文章主要介绍“mybatis一对一查询一对多查询遇到的问题怎么解决”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“mybatis一对一查询一对多查询遇到的问题怎么解决”文章能帮助大家解决问题。实体...
    99+
    2023-06-30
  • 怎么解决Mysql多行子查询的使用及空值问题
    这篇文章主要讲解了“怎么解决Mysql多行子查询的使用及空值问题”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么解决Mysql多行子查询的使用及空值问题”吧!1 定义也称为集合比较子查询内...
    99+
    2023-06-28
  • Linux多线程及多线程并发访问同一块内存的问题怎么解决
    这篇文章主要介绍了Linux多线程及多线程并发访问同一块内存的问题怎么解决的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Linux多线程及多线程并发访问同一块内存的问题怎么解决文章都会有所收获,下面我们一起来看...
    99+
    2023-07-05
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作