MySQL基础 - 游标的使用

游标简介

截止到现在为止,我们只能使用SELECT ... INTO ...语句将一条记录的各个列值赋值到多个变量里,比如在前边的get_score_data存储过程里有这样的语句:

SELECT MAX(score), MIN(score), AVG(score) FROM student_score WHERE subject = s INTO max_score, min_score, avg_score;

但是如果某个查询语句的结果集中有多条记录的话,我们就无法把它们赋值给某些变量了~ 所以为了方便我们去访问这些有多条记录的结果集,MySQL中引入了游标的概念。

我们下边以对t1表的查询为例来介绍一下游标,比如我们有这样一个查询:

mysql> SELECT m1, n1 FROM t1;
+------+------+
| m1   | n1   |
+------+------+
|    1 | a    |
|    2 | b    |
|    3 | c    |
|    4 | d    |
+------+------+
4 rows in set (0.00 sec)

mysql>

这个SELECT m1, n1 FROM t1查询语句对应的结果集有4条记录,游标其实就是用来标记结果集中我们正在访问的某一条记录。初始状态下它标记结果集中的第一条记录,就像这样:

image_1c84n8uvc59177b1bp8niq17a91m.png-8.8kB

我们可以根据这个游标取出它对应记录的信息,随后再移动游标,让它执向下一条记录。游标既可以用在存储函数中,也可以用在存储过程中,我们下边以存储过程为例来说明游标的使用方式,它的使用大致分成这么四个步骤:

  1. 创建游标
  2. 打开游标
  3. 通过游标访问记录
  4. 关闭游标

下边来详细介绍这几个步骤的详细情况。

创建游标

在创建游标的时候,需要指定一下与游标关联的查询语句,语法如下:

DECLARE 游标名称 CURSOR FOR 查询语句;

我们定义一个存储过程试一试:

  • 4
    点赞
  • 44
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
以下是一个三层嵌套游标MySQL 存储过程示例: ``` DELIMITER $$ CREATE PROCEDURE nested_cursor_example() BEGIN DECLARE done INT DEFAULT FALSE; DECLARE a INT; DECLARE b INT; DECLARE c INT; -- 定义外层游标 DECLARE outer_cursor CURSOR FOR SELECT id FROM table1; -- 定义中层游标 DECLARE middle_cursor CURSOR FOR SELECT id FROM table2 WHERE table1_id = a; -- 定义内层游标 DECLARE inner_cursor CURSOR FOR SELECT id FROM table3 WHERE table2_id = b; -- 打开外层游标 OPEN outer_cursor; outer_loop: LOOP -- 获取外层游标当前行数据 FETCH outer_cursor INTO a; IF done THEN LEAVE outer_loop; END IF; -- 打开中层游标 OPEN middle_cursor; middle_loop: LOOP -- 获取中层游标当前行数据 FETCH middle_cursor INTO b; IF done THEN LEAVE middle_loop; END IF; -- 打开内层游标 OPEN inner_cursor; inner_loop: LOOP -- 获取内层游标当前行数据 FETCH inner_cursor INTO c; IF done THEN LEAVE inner_loop; END IF; -- 在此处可以对获取到的数据进行操作 END LOOP; -- 内层游标循环结束 -- 关闭内层游标 CLOSE inner_cursor; END LOOP; -- 中层游标循环结束 -- 关闭中层游标 CLOSE middle_cursor; END LOOP; -- 外层游标循环结束 -- 关闭外层游标 CLOSE outer_cursor; END$$ DELIMITER ; ``` 该存储过程中,外层游标用于遍历 `table1` 表中的数据,中层游标用于在每个外层游标数据的基础上遍历 `table2` 表中符合条件的数据,内层游标用于在每个中层游标数据的基础上遍历 `table3` 表中符合条件的数据。在每个游标的循环中,都可以对获取到的数据进行操作。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

宋同学shl

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值