为了处理SQL语句,存储过程进程分配一段内存区域来保存上下文联系。游标是指向上下文区域的句柄或指针。借助游标,存储过程可以控制上下文区域的变化。
定义游标
CURSOR cursor_name
[ BINARY ] [ NO SCROLL ] [ { WITH | WITHOUT } HOLD ]
FOR query ;
通过已经创建的游标检索数据
FETCH [ direction { FROM | IN } ] cursor_name;
其中direction子句为可选参数。
NEXT
| PRIOR
| FIRST
| LAST
| ABSOLUTE count
| RELATIVE count
| count
| ALL
| FORWARD
| FORWARD count
| FORWARD ALL
| BACKWARD
| BACKWARD count
| BACKWARD ALL
在不检索数据的情况下重新定位一个游标
MOVE的作用类似于FETCH命令,但只是重定位游标而不返回行。
MOVE [ direction [ FROM | IN ] ] cursor_name;
其中direction子句为可选参数。
NEXT
| PRIOR
| FIRST
| LAST
| ABSOLUTE count
| RELATIVE count
| count
| ALL
| FORWARD
| FORWARD count
| FORWARD ALL
| BACKWARD
| BACKWARD count
| BACKWARD ALL
关闭游标,释放和一个游标关联的所有资源
CLOSE { cursor_name | ALL } ;
cursor_name
将要创建、关闭的游标名。
BINARY
指明游标以二进制而不是文本格式返回数据。
NO SCROLL
声明游标检索数据行的方式。
WITH HOLD | WITHOUT HOLD
声明当创建游标的事务结束后,游标是否能继续使用。
query
使用SELECT或VALUES子句指定游标返回的行。
取值范围:SELECT或VALUES子句。
direction_clause
定义抓取数据的方向。
取值范围:
NEXT(缺省值)
从当前关联位置开始,抓取下一行。
PRIOR
从当前关联位置开始,抓取上一行。
FIRST
抓取查询的第一行(和ABSOLUTE 1相同)。
LAST
抓取查询的最后一行(和ABSOLUTE -1相同)。
ABSOLUTE count
抓取查询中第count行。
ABSOLUTE抓取不会比用相对位移移动到需要的数据行更快,因为下层的实现必须遍历所有中间的行。
count取值范围:有符号的整数
RELATIVE count
从当前关联位置开始,抓取随后或前面的第count行。
取值范围:有符号的整数
count
抓取随后的count行(和FORWARD count一样)。
ALL
从当前关联位置开始,抓取所有剩余的行(和FORWARD ALL一样)。
FORWARD
抓取下一行(和NEXT一样)。
FORWARD count
从当前关联位置开始,抓取随后或前面的count行。
FORWARD ALL
从当前关联位置开始,抓取所有剩余行。
BACKWARD
从当前关联位置开始,抓取前面一行(和PRIOR一样) 。
BACKWARD count
从当前关联位置开始,抓取前面的count行(向后扫描)。
取值范围:有符号的整数
BACKWARD ALL
从当前关联位置开始,抓取所有前面的行(向后扫描) 。
{ FROM | IN } cursor_name
使用关键字FROM或IN指定游标名称。
取值范围:已创建的游标的名称。
ALL
关闭所有已打开的游标。
假设存在表customer_t1 ,数据内容如下:
openGauss=# SELECT * FROM customer_t1;
c_customer_sk | c_customer_id | c_first_name | c_last_name | amount
---------------+---------------+--------------+-------------+--------
3769 | | Grace | |
3769 | hello | | |
6885 | maps | Joes | | 2200
4321 | tpcds | Lily | | 3000
9527 | world | James | | 5000
(5 rows)
用一个游标读取一个表。
--开始一个事务。
openGauss=# START TRANSACTION;
START TRANSACTION
--建立一个名为cursor1的游标。
openGauss=# CURSOR cursor1 FOR SELECT * FROM customer_t1;
DECLARE CURSOR
--抓取前3行到游标cursor1里。
openGauss=# FETCH FORWARD 3 FROM cursor1;
c_customer_sk | c_customer_id | c_first_name | c_last_name | amount
---------------+---------------+--------------+-------------+--------
3769 | | Grace | |
3769 | hello | | |
6885 | maps | Joes | | 2200
(3 rows)
--关闭游标并提交事务。
openGauss=# CLOSE cursor1;
CLOSE CURSOR
--结束一个事务。
openGauss=# END;
COMMIT
用一个游标读取VALUES子句中的内容。
--开始一个事务。
openGauss=# START TRANSACTION;
START TRANSACTION
--建立一个名为cursor2的游标。
openGauss=# CURSOR cursor2 FOR VALUES(1,2),(0,3) ORDER BY 1;
DECLARE CURSOR
--抓取前2行到游标cursor2里。
openGauss=# FETCH FORWARD 2 FROM cursor2;
column1 | column2
---------+---------
0 | 3
1 | 2
(2 rows)
--关闭游标并提交事务。
openGauss=# CLOSE cursor2;
CLOSE CURSOR
--结束一个事务。
openGauss=# END;
COMMIT
WITH HOLD游标的使用。
--开启事务。
openGauss=# START TRANSACTION;
--创建一个with hold游标。
openGauss=# DECLARE cursor1 CURSOR WITH HOLD FOR SELECT * FROM customer_t1;
--抓取头2行到游标cursor1里。
openGauss=# FETCH FORWARD 2 FROM cursor1;
c_customer_sk | c_customer_id | c_first_name | c_last_name | amount
---------------+---------------+--------------+-------------+--------
3769 | | Grace | |
3769 | hello | | |
(2 rows)
--结束事务。
openGauss=# END;
COMMIT
--抓取下一行到游标cursor1里。
openGauss=# FETCH FORWARD 1 FROM cursor1;
c_customer_sk | c_customer_id | c_first_name | c_last_name | amount
---------------+---------------+--------------+-------------+--------
6885 | maps | Joes | | 2200
(1 row)
--关闭游标。
openGauss=# CLOSE cursor1;
CLOSE CURSOR
MOVE语句的使用。
--开始一个事务。
openGauss=# START TRANSACTION;
START TRANSACTION
--定义一个名为cursor1的游标。
openGauss=# CURSOR cursor1 FOR SELECT * FROM customer_t1;
DECLARE CURSOR
--忽略游标cursor1的前3行。
openGauss=# MOVE FORWARD 1 FROM cursor1;
MOVE 1
--抓取游标cursor1的前2行。
openGauss=# FETCH 2 FROM cursor1;
c_customer_sk | c_customer_id | c_first_name | c_last_name | amount
---------------+---------------+--------------+-------------+--------
3769 | hello | | |
6885 | maps | Joes | | 2200
(2 rows)
--关闭游标。
openGauss=# CLOSE cursor1;
CLOSE CURSOR
--结束一个事务。
openGauss=# END;
COMMIT
点赞,你的认可是我创作的动力!
⭐️ 收藏,你的青睐是我努力的方向!
✏️ 评论,你的意见是我进步的财富!