GBase 8s兼容O的PL/SQL编程语言,包括PL/SOL支持的数据类型,变量声明、赋值语法,顺序、选择、循环分支语法,集合、记录对象的使用,静态SQL、动态SQL语法以及错误处理等。本文主要介绍在数据库编程中,静态游标的使用方法。GBase 8s数据库提供了两种类型的静态游标:隐式游标和显式游标。本文将详细介绍GBase 8s中的静态游标,包括它们的使用场景、特点以及如何有效利用它们来提高数据库操作的效率。
静态游标是只读游标,它总是按照打开游标时的原样显示结果集,在编译时就能确定静态游标使用的查询。
隐式游标:
隐式游标无需用户进行定义,每当用户在兼容O模式 的 PL/SQL 程序中执行一个 DML 语句(INSERT、UPDATE、DELETE)或者 SELECT...INTO 语句时,会自动声明一个隐式游标并管理这个游标。
1、隐式游标的特点:
- 隐式游标是由PL/SQL 来管理的, 即不需要声明游标语句, 也不需要OPEN,FETCH,CLOSE 操作;
- 隐式游标中必须要有select cur_name into [ 变量名或其他数据类型]. 此句完成OPEN,FETCH,CLOSE 操作;
- 隐式游标只能返回一行记录, 如果无符合条件的记录将会出现NO_DATA_FOUND 异常. 如果出现多条记录将出现TOO_MANY_ROWS 异常;
- 隐式游标只能用SQL% 判断其游标属性;
- 对于任何位置使用SQL%ISOPEN 结果都是FALSE, 隐式游标由PL/SQL 管理;
- 对于在隐式游标位置前使用SQL%FOUND 或SQL%NOTFOUND, SQL%ROWCOUNT 结果值是NULL( 不确定值)。
2、隐式游标支持的属性:
SQL%ISOPEN
(1)含义:游标是否打开;
(2)始终返回false,因为隐式游标在关联语句执行完后永远是关闭的。
SQL%FOUND
(1)含义:是否有行受影响;
(2)返回NULL:没有select或dml运行;
(3)返回TRUE:有返回,影响一行或多行;
(4)返回FALSE:其它情况。
SQL%NOTFOUND
(1)含义:是否没有受影响的行;
(2)返回NULL:没有select或dml运行;
(3)返回TRUE:其它情况;
(4)返回FALSE:有返回,影响一行或多行。
SQL%ROWCOUNT
(1)含义:返回被影响的行数;
(2)返回NULL:没有select或dml运行;
(3)返回其它值:影响的行数。
显示游标
1、显示游标的特点:
(1)显式游标由用户构造和管理;
(2)必须声明显示游标,并给他命名和关联一个查询语句;
(3)显示游标不支持赋值,不能在表达式中使用,不能作为子程序的参数或宿主变量使用;
(4)如不得不使用,则选择使用游标变量来实现。
2、使用显示游标的步骤:
(1)定义游标:声明游标及其关联的查询语句;
(2)打开游标:执行游标关联的语句,将查询结果装入游标工作区,将游标定位到结果集的第一行之前;
(3)拨动游标:根据应用需要将游标位置移动到结果集的合适位置;
(4)关闭游标:游标使用完后应关闭,以释放其占有的资源。
3、游标的使用:
游标声明和定义
DECLARE
--声明c1
CURSOR c1 RETURN departments%ROWTYPE;
--声明并定义c2
CURSOR c2 IS SELECT employee_id, job_id, salary FROM employees WHERE salary > 2000;
--定义c1
CURSOR c1 RETURN departments%ROWTYPE IS SELECT * FROM departments WHERE department_id = 110;
--声明c3
CURSOR c3;
--定义c3
CURSOR c3 IS SELECT * FROM locations WHERE country_id = 'JP';
BEGIN
NULL;
END;
/
into到普通变量
--创建表
create table t(id int,name varchar(10));
insert into t values(1,'jack');
insert into t values(2,'jerry');
declare
v1 int;
v2 varchar(10);
cursor c1 is select id, name from t;
begin
open c1;
loop
fetch c1 into v1,v2;
exit when c1%notfound;
dbms_output.put_line('id = '||v1);
dbms_output.put_line('name = '||v2);
end loop;
close c1;
end;
/
into到record类型变量
--创建表
create table t(id int,name varchar(10));
insert into t values(1,'jack');
insert into t values(2,'jerry');
declare
v t%rowtype;
cursor c1 is select id, name from t;
begin
open c1;
loop
fetch c1 into v;
exit when c1%notfound;
dbms_output.put_line('id = '||v.id);
dbms_output.put_line('name = '||v.name);
end loop;
close c1;
end;
/
带参数的游标(调用前open)
--创建表
create table t(id int,name varchar(10));
insert into t values(1,'jack');
insert into t values(2,'jerry');
declare
cursor c (c_id int) is select name from t where id = c_id;
--定义存储过程
procedure p1 is
p_name varchar(10);
begin
loop
fetch c into p_name;
exit when c%notfound;
dbms_output.put_line('result is: '||p_name);
end loop;
end;
begin
open c(2); --打开游标
p1; --调用存储过程
close c; --关闭游标
end;
/
通过本文的详细介绍,您了解GBase 8s中的静态游标及其应用。合理使用游标不仅可以提高数据库查询的效率,还可以使代码更加清晰和易于维护。希望本文能帮助您更好地利用GBase 8s的游标功能,感谢您的阅读。