本教程操作环境:windows7系统、mysql8版本、dell g3电脑。
在 mysql 中,存储过程或函数中的查询有时会返回多条记录,而使用简单的 select 语句,没有办法得到第一行、下一行或前十行的数据,这时可以使用游标来逐条读取查询结果集中的记录。游标在部分资料中也被称为光标。
游标简介
1、游标:也称为光标,是一个存储在dbms服务器上的数据库查询,它不是一条select语句,而是被该语句检索出来的结果集。
2、用途:对检索出来的数据进行前进或者后退操作,主要用于交互式应用,如用户滚动屏幕上的数据
3、特性:
能够标记游标为只读,使数据能读取,但不能更新和删除能控制可以执行的定向操作(向前、向后、第一、最后、绝对位置、相对位置等)能标记某些列为可编辑的,某些列为不可编辑的规定范围,使游标对创建它的特定请求(如存储过程)或对所有请求可访问只是dbms对检索出的数据(而不是指出表中活动数据)进行复制,使数据在游标打开和访问期间不变化4、支持游标的dbms:db2、mariadb、mysql 5、sql server、sqlite、oracle和postgresql,而microsoft access不支持
5、游标对基于web的应用用处不大(asp、asp.net、coldfusion、php、python、ruby、jsp等),大多数web应用开发人员不使用游标
6、使用:
声明游标: declare cursor_name cursor for select * from table_name; // 还没有检索数据-- mysql游标的声明declare cursor_name cursor for select_statement-- sql server游标的声明declare cursor_name cursor for select_statement [for [read only | update {[co lumn_list]}]]-- oracle游标的声明declare corsor cursor_name is {select_statement}
打开游标:open cursor_name; // 开始检索数据,即指定游标的select语句被执行,并且查询的结果集被保存在内存里的特定区域。-- mysql打开游标open cursor_name-- sql server打开游标open cursor_name-- oracle打开游标open cursor_name [param1 [, param2]]
获取数据:fetch cursor_name into var1,var2,...,varn; // 当游标cursor_name检索完数据后,只有等到下一次fetch时才会触发结束的标志-- mysql游标获取数据fetch cursor_name into var1_name [, var2_name] ...-- sql server游标获取数据fetch next from cursor_name [into fetch_list]-- oracle游标获取数据fetch cursor_name {into : host_var1 [[indicator] : indicator_var1] [, : host_var2 [[indicator] : indicator_var2]] | using descriptor descriptor}
关闭游标:close cursor_name;-- mysql关闭游标,会主动释放资源,所以不需要deallocate语句close cursor_name-- sql server关闭游标和释放资源close cursor_namedeallocate cursor_name-- oracle关闭游标,会主动释放资源,所以不需要deallocate语句close cursor_name
【相关推荐:mysql视频教程】
以上就是mysql存储过程的游标是什么的详细内容。
