mysql存储过程的游标有什么作用

网友投稿 380 2023-11-27

mysql存储过程的游标有什么作用

这篇文章主要讲解了“mysql存储过程的游标有什么作用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“mysql存储过程的游标有什么作用”吧!

mysql存储过程的游标有什么作用

在mysql存储过程中,游标也称为光标,是一个存储在DBMS服务器上的数据库查询,是检索操作返回一组结果集,一般用于对检索出来的数据进行前进或者后退操作。

本教程操作环境: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 FORselect_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_name DEALLOCATE cursor_name -- Oracle关闭游标,会主动释放资源,所以不需要DEALLOCATE语句 CLOSE cursor_name

感谢各位的阅读,以上就是“mysql存储过程的游标有什么作用”的内容了,经过本文的学习后,相信大家对mysql存储过程的游标有什么作用这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是,小编将为大家推送更多相关知识点的文章,欢迎关注!

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:MySql Group by函数怎么正确使用
下一篇:mysql存储过程中如何定义变量
相关文章

 发表评论

暂时没有评论,来抢沙发吧~