最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

mysql数据库中关于Cursor游标的使用方法_MySQL

来源:动视网 责编:小采 时间:2020-11-09 17:53:02
文档

mysql数据库中关于Cursor游标的使用方法_MySQL

mysql数据库中关于Cursor游标的使用方法_MySQL:mysql数据库中关于Cursor游标的使用方法 DECLARE cursor_name CURSOR FOR SELECT_statement; 游标操作 OPEN 打开游标 OPEN cursor_name; FETCH 获取游标当前指针的记录,并传给指定变量列表,注意变量数必须与MySQL游标返回的字段数一致,要获得多行数据
推荐度:
导读mysql数据库中关于Cursor游标的使用方法_MySQL:mysql数据库中关于Cursor游标的使用方法 DECLARE cursor_name CURSOR FOR SELECT_statement; 游标操作 OPEN 打开游标 OPEN cursor_name; FETCH 获取游标当前指针的记录,并传给指定变量列表,注意变量数必须与MySQL游标返回的字段数一致,要获得多行数据


========
游标的Handler

mysql> DELIMITER //
mysql> CREATE FUNCTION city_list() RETURNS VARCHAR(255)
-> BEGIN
->
-> DECLARE finished INTEGER DEFAULT 0;
-> DECLARE city_name VARCHAR(50) DEFAULT "";
-> DECLARE list VARCHAR(255) DEFAULT "";
-> DECLARE city_cur CURSOR FOR SELECT city FROM employee;
-> DECLARE CONTINUE HANDLER FOR NOT FOUND SET finished = 1;
->
-> OPEN city_cur;
->
-> get_city: LOOP
-> FETCH city_cur INTO city_name;
-> IF finished THEN
-> LEAVE get_city;
-> END IF;
-> SET list = CONCAT(list,", ",city_name);
-> END LOOP get_city;
->
-> CLOSE city_cur;
->
-> RETURN SUBSTR(list,3);
-> END
-> //
Query OK, 0 rows affected (0.00 sec)

mysql> DELIMITER ;
mysql>
mysql> SELECT city_list() AS cities;
+------------------------------------------------------------------------------------+
| cities |
+------------------------------------------------------------------------------------+
| Toronto, Vancouver, Vancouver, Vancouver, Vancouver, New York, New York, Vancouver |
+------------------------------------------------------------------------------------+
1 row in set (0.02 sec)

mysql>
mysql> drop function city_list;
Query OK, 0 rows affected (0.00 sec)

mysql>
mysql>
mysql>
mysql> drop table Employee;
Query OK, 0 rows affected (0.00 sec)
====


mysql 游标数据输出实例

mysql> delimiter $$
mysql> CREATE PROCEDURE myProc()
-> READS SQL DATA
-> BEGIN
-> DECLARE l_last_row INT DEFAULT 0;
-> DECLARE l_dept_id INT;
-> DECLARE c_dept CURSOR FOR
-> SELECT id
-> FROM employee;
-> /* handler to set l_last_row=1 if a cursor returns no more rows */
-> DECLARE continue handler for NOT FOUND SET l_last_row=1;
->
-> OPEN c_dept;
-> dept_cursor: LOOP
-> FETCH c_dept INTO l_dept_id;
-> IF (l_last_row=1) THEN
-> LEAVE dept_cursor;
-> END IF;
-> select l_dept_id;
->
-> END LOOP dept_cursor;
-> CLOSE c_dept;
->
-> END$$
Query OK, 0 rows affected (0.01 sec)

mysql>
mysql> delimiter ;

文档

mysql数据库中关于Cursor游标的使用方法_MySQL

mysql数据库中关于Cursor游标的使用方法_MySQL:mysql数据库中关于Cursor游标的使用方法 DECLARE cursor_name CURSOR FOR SELECT_statement; 游标操作 OPEN 打开游标 OPEN cursor_name; FETCH 获取游标当前指针的记录,并传给指定变量列表,注意变量数必须与MySQL游标返回的字段数一致,要获得多行数据
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top