一,什么是游标(cursor)
个人觉得就是一个cursor,就是一个标识,用来标识数据去到什么地方了。你也可以把它理解成数组中的下标。
二,游标(cursor)的特性
1.只读的,不能更新的。
2.不滚动的
3.不敏感的,不敏感意为服务器可以或不可以复制它的结果
三,使用游标(cursor)
1.声明游标
这个语句声明一个游标。也可以在子程序中定义多个游标,但是一个块中的每一个游标必须有唯一的名字。声明游标后也是单条操作的, 但是不能用SELECT语句不能有INTO子句。
2. 游标OPEN语句
这个语句打开先前声明的游标。
3. 游标FETCH语句
这个语句用指定的打开游标读取下一行(如果有下一行的话),并且前进游标指针。
4. 游标CLOSE语句
这个语句关闭先前打开的游标。
四,应用举例
调用时因为是out类型的参数所以需要变量来取值:
个人觉得就是一个cursor,就是一个标识,用来标识数据去到什么地方了。你也可以把它理解成数组中的下标。
二,游标(cursor)的特性
1.只读的,不能更新的。
2.不滚动的
3.不敏感的,不敏感意为服务器可以或不可以复制它的结果
游标(cursor)必须在声明处理程序之前被声明,并且变量和条件必须在声明游标或处理程序之前被声明。
4.不像多数DBMS,MySQL游标只能用于存储过程和函数。
三,使用游标(cursor)
1.声明游标
- DECLARE cursor_name CURSOR FOR select_statement
这个语句声明一个游标。也可以在子程序中定义多个游标,但是一个块中的每一个游标必须有唯一的名字。声明游标后也是单条操作的, 但是不能用SELECT语句不能有INTO子句。
2. 游标OPEN语句
- OPEN cursor_name ;
这个语句打开先前声明的游标。
3. 游标FETCH语句
- FETCH cursor_name INTO var_name [, var_name] ...
这个语句用指定的打开游标读取下一行(如果有下一行的话),并且前进游标指针。
4. 游标CLOSE语句
- CLOSE cursor_name ;
这个语句关闭先前打开的游标。
四,应用举例
- drop procedure if exists test_cursor ;
- -- delimiter表示以//结束编译
- delimiter //
- create procedure getResultFromTest(out result varchar(128))
- begin
- -- 游标所使用变量需要在定义游标之前申明
- declare id int(11);
- declare name varchar(20);
- -- 遍历数据结束标志 注意位置顺序
- DECLARE done INT DEFAULT FALSE;
- -- 注意用别名 因为id在上面已经有定义所以需要使用表的别名区别
- declare cur_test CURSOR for select t.id,t.name from test t;
- -- 将结束标志绑定到游标
- DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE;
- open cur_test;
- repeat
- fetch cur_test into id, name;
- select id ;
- -- concat_ws函数用逗号后面的参数隔开 concat_ws(',','12','33','332') --> 12,33,332
- select concat_ws(',',result,id,name) into result ;
- until done
- end repeat;
- --注意关闭游标
- close cur_test;
- select result ;
- end;
- //
- delimiter ;
调用时因为是out类型的参数所以需要变量来取值:
- mysql>set @id = ''; --需要赋值 否则报错
- mysql>call getResultFromTest(@id);