当前位置:Gxlcms > mysql > mysql游标不到数据问题以及解决方案

mysql游标不到数据问题以及解决方案

时间:2021-07-01 10:21:17 帮助过:67人阅读

前几天遇到一个mysql游标不到数据问题,这个问题困扰了我两天,现在终于解决了,下面小编就来为大家分享一下。

这是建表语句,插入两行数据

  1. drop table如果存在testinfo;
  2. 创建表testinfo
  3. name varchar(10)not null,
  4. 年龄int
  5. );
  6. truncate table testinfo;
  7. 插入testinfo()值('你',15);
  8. 插入testinfo()值('me',20);

查询的表数据

  1. mysql> select name,age from testinfo;
  2. + ------ + ------ +
  3. | 名称| 年龄|
  4. + ------ + ------ +
  5. | 你| 15 |
  6. | 我| 20 |
  7. + ------ + ------ +
  8. 这是使用游标的存储过程
  9. drop procedure if exists test_proc;
  10. 分隔符//
  11. 创建过程test_proc()
  12. 开始
  13. DECLARE done int default false;
  14. DECLARE一个char(10);
  15. DECLARE b int;
  16. DECLARE cur1游标用于选择名称,age from testinfo;
  17. DECLARE继续处理SQLSTATE'02000'set done = true;
  18. 打开cur1;
  19. read_loop:loop
  20. FETCh cur1进入a,b;
  21. 如果这样做了
  22. 离开read_loop
  23. 万一;
  24. 选择@ a,@ b;
  25. 插入testinfo值(@ a,@ b);
  26. 端环;
  27. 关闭cur1;
  28. 结束
  29. //
  30. 分隔符
  31. 调用test_proc();

执行结果如下

  1. mysql> \。/opt/mysql/test_proc.sql
  2. 查询行,受影响的0行,1个警告(0.00秒)
  3. 查询行,受影响(0.02秒)0行
  4. + ------ + ------ +
  5. | @a | @b |
  6. + ------ + ------ +
  7. | NULL | NULL |
  8. + ------ + ------ +
  9. 1行集(0.00秒)

上面是有错误的:1048(23000):列'名称'不能为空

不知道错在哪里,为什么取
不到数据? 两天了,现在终于知道了。应该这么改,l如下:

插入testinfo值(@ a,@ b);改成插入testinfo值(a,b);就好了
声明了变量a,b,然后通过游标给他赋值,但是并没有给@ a,@ b赋值..

所以遇到问题要仔细看看就容易解决的。

【相关推荐】

1. 免费mysql在线视频教程

2. MySQL最新手册教程

3. 数据库设计那些事

以上就是mysql游标不到数据问题以及解决方案的详细内容,更多请关注Gxl网其它相关文章!

人气教程排行