mysql游标不到数据问题以及解决方案
程序员文章站
2022-03-08 11:08:27
...
前几天遇到一个mysql游标不到数据问题,这个问题困扰了我两天,现在终于解决了,下面小编就来为大家分享一下。
这是建表语句,插入两行数据
drop table如果存在testinfo; 创建表testinfo ( name varchar(10)not null, 年龄int ); truncate table testinfo; 插入testinfo()值('你',15); 插入testinfo()值('me',20);
查询的表数据
mysql> select name,age from testinfo; + ------ + ------ + | 名称| 年龄| + ------ + ------ + | 你| 15 | | 我| 20 | + ------ + ------ + 这是使用游标的存储过程 drop procedure if exists test_proc; 分隔符// 创建过程test_proc() 开始 DECLARE done int default false; DECLARE一个char(10); DECLARE b int; DECLARE cur1游标用于选择名称,age from testinfo; DECLARE继续处理SQLSTATE'02000'set done = true; 打开cur1; read_loop:loop FETCh cur1进入a,b; 如果这样做了 离开read_loop 万一; 选择@ a,@ b; 插入testinfo值(@ a,@ b); 端环; 关闭cur1; 结束 // 分隔符 调用test_proc();
执行结果如下
mysql> \。/opt/mysql/test_proc.sql 查询行,受影响的0行,1个警告(0.00秒) 查询行,受影响(0.02秒)0行 + ------ + ------ + | @a | @b | + ------ + ------ + | NULL | NULL | + ------ + ------ + 1行集(0.00秒)
上面是有错误的:1048(23000):列'名称'不能为空
不知道错在哪里,为什么取
不到数据? 两天了,现在终于知道了。应该这么改,l如下:
插入testinfo值(@ a,@ b);改成插入testinfo值(a,b);就好了
声明了变量a,b,然后通过游标给他赋值,但是并没有给@ a,@ b赋值..
所以遇到问题要仔细看看就容易解决的。
【相关推荐】
2. MySQL最新手册教程
3. 数据库设计那些事
以上就是mysql游标不到数据问题以及解决方案的详细内容,更多请关注其它相关文章!
推荐阅读
-
mysql插入表数据中文乱码问题解决方案
-
Python中LOADDATAINFILE语句导入数据到MySQL遇到问题的解决方案分享
-
mysql修改密码、找不到mysql数据库、mysql1045等问题的解决办法
-
SqlServer Mysql数据库修改自增列的值及相应问题的解决方案
-
Mysql数据库无法启动问题的解决方案
-
分析Mysql大量数据导入遇到的问题以及解决方案
-
Mysql匿名登录无法创建数据库问题解决方案
-
MyEclipse连接MySQL数据库出现的问题以及解决办法
-
linux上 mysql 的安装,以及解决不能远程访问数据库系统的问题
-
在控制台中操作MYSQL数据库步骤以及一些小问题