首頁  >  文章  >  資料庫  >  mysql遊標不到資料問題以及解決方案

mysql遊標不到資料問題以及解決方案

零下一度
零下一度原創
2017-05-12 11:04:412849瀏覽

前幾天遇到一個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賦值..

所以遇到問題要仔細看看就容易解決的。

【相關推薦】

1. 免費mysql線上影片教學

2. MySQL最新手冊教學

#3. 資料庫設計那些事

以上是mysql遊標不到資料問題以及解決方案的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn