Oracle02_游标、集合、和OOP的概念(高级应用)
oracle中游标的用法
什么是游标cursor?类似于编程语言里的指针,指向你要读取的记录类型:隐式游标系统定义好的,立刻可以使用:SQL显式游标用户自己定义的游标创建===》打开===》访问===》关闭游标的属性:%found :用来表明游标里是否还有记录%notfound :用来表明游标里是否没有记录%rowcount : 表示游标已经访问到的记录数%isopen :用来判断游标是否打开隐式游标:SQL> declare2 v_number number;3 begin4 select count(*) into v_number from emp;5 dbms_output.put_line(sql%rowcount);6* end;SQL> /1显示游标样例:SQL> l1 declare2 cursor emp_cursor is3 select ename from emp; //游标定义4 v_name emp.ename%type;5 begin6 open emp_cursor; //打开游标7 fetch emp_cursor into v_name; //访问游标8 while emp_cursor%found loop9 dbms_output.put_line(v_name);10 fetch emp_cursor into v_name;11 end loop;12 close emp_cursor; //关闭游标13* end;//利用%rowcount游标属性,进行循环输出控制SQL> l1 declare2 cursor emp_cursor is3 select ename from emp;4 v_name emp.ename%type;5 begin6 open emp_cursor;7 fetch emp_cursor into v_name;8 while emp_cursor%found loop9 dbms_output.put_line(v_name);10 exit when emp_cursor%rowcount >= 5;11 fetch emp_cursor into v_name;12 end loop;13 close emp_cursor;14* end;SQL> /定义有参数的游标://实现带有参数的游标,具体功能输出empno大于输入变量emp_no的员工名单列表SQL> l1 declare2 cursor emp_empno(v_empno in number) is3 select ename from emp where empno > v_empno;4 v_ename emp.ename%type;5 begin6 open emp_empno(&emp_no);7 fetch emp_empno into v_ename;8 while emp_empno%found loop9 dbms_output.put_line(v_ename);10 fetch emp_empno into v_ename;11 end loop;12 close emp_empno;13* end;SQL> ///实现多列输出:SQL> declare2 cursor emp_nasal is3 select ename,sal from emp;4 v_ename emp.ename%type;5 v_sal emp.sal%type;6 begin7 open emp_nasal;8 fetch emp_nasal into v_ename,v_sal;9 while emp_nasal%found loop10 dbms_output.put_line(v_ename || ': his salary is ' || to_char(v_sal,'L99,999.99'));11 fetch emp_nasal into v_ename,v_sal;12 end loop;13 close emp_nasal;14 end;15 /使用record来实现多列输出:TYPE type_name is record ( field_declaration, [field_ceclaration]);field_declaration: field_name (field_type | vairable%type)SQL> declare2 cursor emp_nasal is3 select ename,sal from emp;45 type emp_ns is record6 ( v_ename emp.ename%type,7 v_sal emp.sal%type); //定义record89 emp_ns_1 emp_ns; //定义record类型的变量emp_ns_110 begin11 open emp_nasal;12 fetch emp_nasal into emp_ns_1;13 while emp_nasal%found loop14 dbms_output.put_line(emp_ns_1.v_ename || ' : ' || emp_ns_1.v_sal);//record的所属变量引用15 fetch emp_nasal into emp_ns_1;16 end loop;17 close emp_nasal;18 end;19 /动态游标:强类型的动态游标弱类型的动态游标强类型动态游标示例:SQL> l1 declare2 type emp_type is record(3 emp_id emp.empno%type,4 emp_name emp.ename%type); //定义一个record:emp_type5 type emp_cursor is ref cursor return emp_type; //定义一个游标类型//红色区域表示固定关键字,emp_cursor是类型名,emp_type返回值类型;6 v_empno emp.empno%type := &out_empno;7 employee emp_type;8 employee_cursor emp_cursor; //定义一个游标类型的变量;9 begin10 if v_empno > 780011 then12 open employee_cursor for13 select empno,ename from emp where empno > v_empno;//定义具体的游标的记录集14 else15 open employee_cursor for16 select empno,ename from emp where empno < v_empno;17 end if;18 fetch employee_cursor into employee; //访问数据19 while employee_cursor%found loop20 dbms_output.put_line(employee.emp_id ||': ' ||employee.emp_name );21 fetch employee_cursor into employee;22 end loop;23 close employee_cursor; //关闭游标24* end;弱类型动态游标示例:SQL> l1 declare2 type emp_type is record (3 emp_id emp.empno%type,4 emp_name emp.ename%type);5 type emp_cursor is ref cursor;6 v_empno emp.empno%type := &out_empno;7 employee emp_type;8 employee_cursor emp_cursor;9 begin10 if v_empno > 780011 then12 open employee_cursor for13 select empno,ename from emp where empno > v_empno;14 else15 open employee_cursor for16 select empno,ename from emp where empno < v_empno;17 end if;18 fetch employee_cursor into employee;19 while employee_cursor%found loop20 dbms_output.put_line(employee.emp_id || ': ' || employee.emp_name);21 fetch employee_cursor into employee;22 end loop;close employee_cursor;23* end;//强类型和弱类型的区别就在于是否存在返回值类型;//如果有明确的返回值类型,那就是强类型动态游标//如果没有明确的返回值类型,那就是弱类型的动态游标;查看系统允许的最大游标数量:SQL> show parameter open_cursors;NAME TYPE V ALUE------------------------------------ ----------- ------------------------------open_cursors integer 300使用table:类似于其他编程语言中的数组结构;有两部分组成:主键: binary_integer 类型列:标量或者记录类型;语法格式:TYPE type_name IS TABLE OF[column_type | variable%type | table.column%type ][index by binary_integer];idetifier type_name;示例:SQL> l1 declare2 type emp_table_type is table of emp.ename%type index by binary_integer;3 emp_table emp_table_type;4 begin5 emp_table(1) := 'haha';6 if emp_table.exists(1) then7 insert into emp(empno,ename) values(1234,emp_table(1));8 end if;9 commit;10* end;SQL> /cursor for:SQL> begin2 for rows in (select ename,sal from emp) loop3 dbms_output.put_line(rows.ename)4 ;5 end loop;6 end;7 /。
oracle 游标的使用方法
oracle 游标的使用方法The use of Oracle cursors is an essential aspect of working with the Oracle database. 游标是一种在Oracle数据库中非常重要的使用方法。
A cursor allows the user to traverse through a result set and process each individual row. 游标允许用户遍历结果集并处理每个单独的行。
This is particularly useful when working with large datasets and needing to perform operations on each row or when only a single row needs to be processed at a time. 当处理大型数据集并且需要对每一行执行操作时,这是非常有用的。
In Oracle, there are two types of cursors: implicit and explicit. 在Oracle中,有两种类型的游标:隐式和显式。
Implicit cursors are automatically created by Oracle when a SELECT, INSERT, UPDATE, or DELETE statement is executed. 隐式游标在执行SELECT、INSERT、UPDATE或DELETE语句时,Oracle会自动创建。
This type of cursor is often used for simple queries where the user does not need to define and manage the cursor explicitly. 这种类型的游标通常用于简单的查询,用户不需要显式定义和管理游标。
Oracle游标
【转】Oracle游标一. 游标PL/SQL 是用游标来管理 SQL 的 SELECT 语句的 . 游标是为了处理这些语句而分配的一大块内存 . 它提供了对一个结果集进行逐行处理的能力 , 可看作是一种特殊的指针 . 它与某个查询结果集相关联 , 可以指向结果集的任意位置 , 以便对指定位置的数据进行处理 . 使用它可以在查询数据的同时对数据进行处理.二. 游标的属性1.%FOUND: 判断当前游标是否正确的指向第一行记录,如果是则返回true,不是则返回false。
2.%NOTFOUND:与%FOUND相反3.%ISOPEN: 判断游标是否打开,如果是的话,就返回true,不是则返回false.4.%ROWCOUNT:判断当前游标在所指向的结果集中的提取的行数,不是所有的记录数.SQL%FOUND和SQL%NOTFOUND在执行任何DML语句前SQL%FOUND和SQL%NOTFOUND的值都是NULL,在执行DML语句后,SQL%FOUND的属性值将是:. TRUE :INSERT. TRUE :DELETE和UPDATE,至少有一行被DELETE或UPDATE.. TRUE :SELECT INTO至少返回一行当SQL%FOUND为TRUE时,SQL%NOTFOUND为FALSE。
另外,有两个变量属性1.%TYPE: 声明变量的类型与表中的某列的数据类型完全一致.它的好处有:一.是你不必知道某列的确切数据类型.二:当某列的数据类型改变时不用修改变量的数据类型.不但列名可以使用%TYPE,而且变量、游标、记录,或声明的常量都可以使用%TYPE.2.%ROWTYPE:声明变量的数据类型与表中的行记录数据类型一致. 对于自定义的记录, 则必须声明自己的域.三.游标的类型1.静态游标静态游标只是数据的一个快照,用户对记录所做的修改,增加或删除记录都不会反映到记录集中。
静态游标从不检测其他的更新、删除和插入情况。
oracle 游标用法
oracle 游标用法Oracle游标是一种用于在PL/SQL中处理查询结果的机制。
游标可以让程序员逐行处理查询结果,而不是一次性将所有结果读入内存。
本文将详细介绍Oracle游标的用法。
一、游标概述1.1 游标的定义游标是一个指向查询结果集的指针,程序员可以使用它来逐行处理查询结果。
1.2 游标的类型Oracle支持显式和隐式两种类型的游标。
显式游标需要明确地声明和打开,而隐式游标则由Oracle自动管理。
1.3 游标的优点使用游标可以减少内存占用,提高程序性能。
同时,它也提供了更灵活的数据处理方式。
二、显式游标2.1 游标声明在PL/SQL中声明一个显式游标需要使用CURSOR关键字。
下面是一个例子:DECLARECURSOR c_emp IS SELECT * FROM emp;BEGIN-- do something hereEND;这个例子声明了一个名为c_emp的游标,它指向emp表中所有记录。
2.2 游标打开在使用之前,需要先打开一个已声明的游标。
可以使用OPEN语句来打开一个显式游标:DECLARECURSOR c_emp IS SELECT * FROM emp;BEGINOPEN c_emp;END;2.3 游标读取数据打开之后,我们可以使用FETCH语句来逐行读取游标指向的结果集。
FETCH语句可以用于一个或多个变量,它会将查询结果赋值给这些变量。
下面是一个例子:DECLARECURSOR c_emp IS SELECT * FROM emp;v_empno emp.empno%TYPE;v_ename emp.ename%TYPE;BEGINOPEN c_emp;FETCH c_emp INTO v_empno, v_ename;END;这个例子从c_emp游标中读取了一行数据,并将empno和ename 分别赋值给了v_empno和v_ename。
2.4 游标关闭在使用完毕后,需要关闭已打开的游标。
oracle__游标的高级应用全解
dbms_output.put_line('结果集已经处理完了');
exit;--及时退出
end if;
end loop;
end;
总结:有参数、无返回值的游标的说明
A:一般步骤(声明游标、打开游标、读取数据、关闭游标);
v_ename emp.ename%type,
v_sal emp.sal%type);
emp_record emp_record_type;
cursor ename_sal_cursor(c_deptno number,c_job varchar2)--声明带参数、有返回值的游标、并与SELECT语句相结合
from emp
where deptno=c_deptno
and job=c_job;
v_emp_record dj_cursor%rowtype;--基于游标的记录变量,可以接收多行数据
begin
open dj_cursor(20,'ANALYST');
loop
fetch dj_cursor into v_emp_record;
fetch cursor_name into name,job,sal;
end loop;
close cursor_name;--关闭游标
end;
--D:关闭游标
begin
…………………………
close cursor_name;
end;
------------2)显式游标属性
select ename,hiredate
from emp
where deptno=c_deptno and job=c_job;--条件用于接收参数变量
oracle游标的用法
oracle游标的用法Oracle游标的用法本文将针对Oracle数据库中游标的用法进行详细讲解。
以下是一些常用的游标用法:1.隐式游标隐式游标是Oracle数据库默认为每个SQL语句自动创建的游标。
使用隐式游标时,我们可以通过%ROWCOUNT系统变量获取受影响的行数,通过%FOUND、%NOTFOUND和%ISOPEN系统变量判断该游标的状态。
示例代码:DECLAREl_count NUMBER;BEGINUPDATE employees SET salary = salary * ;l_count := SQL%ROWCOUNT;IF SQL%FOUND THENDBMS__LINE('成功更新了 ' || l_count || ' 条记录。
');END IF;END;2.显式游标显式游标是由程序员显式创建和控制的游标。
与隐式游标相比,显式游标提供了更大的灵活性,可以更好地处理大量的数据。
示例代码:DECLARECURSOR cursor_name IS SELECT * FROM employees;l_employee employees%ROWTYPE;BEGINOPEN cursor_name;LOOPFETCH cursor_name INTO l_employee;EXIT WHEN cursor_name%NOTFOUND;-- 对l_employee进行处理END LOOP;CLOSE cursor_name;END;在上述示例代码中,我们使用显式游标cursor_name查询了employees表的所有记录。
然后,通过循环获取每一条记录并对其进行处理,直到游标的%NOTFOUND属性为真时退出循环。
3.游标参数化游标参数化允许我们在游标声明中传递参数,以动态地定义游标查询的条件。
通过参数化游标,我们可以根据不同的条件查询不同的数据集。
示例代码:DECLARECURSOR cursor_name (param1 VARCHAR2, param2 NUMB ER) ISSELECT * FROM employees WHERE department_id = param1 AND salary > param2;l_employee employees%ROWTYPE;BEGINOPEN cursor_name('IT', 5000);LOOPFETCH cursor_name INTO l_employee;EXIT WHEN cursor_name%NOTFOUND;-- 对l_employee进行处理END LOOP;CLOSE cursor_name;END;在上述示例代码中,我们使用参数化游标cursor_name查询了部门ID为’IT’且薪水大于5000的员工信息。
Oracle游标详解
Oracle游标详解1、游标的概念游标(CURSOR):游标是把从数据表中提取出来的数据,以临时表的形式存放在内存中,在游标中有⼀个数据指针,在初始状态下指向的是⾸记录,利⽤fetch语句可以移动该指针,从⽽对游标中的数据进⾏各种操作。
2、游标的作⽤游标是⽤来处理使⽤SELECT语句从数据库中检索到的多⾏记录的⼯具。
借助于游标的功能,数据库应⽤程序可以对⼀组记录逐条进⾏处理,每次处理⼀⾏。
3、游标的类型显式游标(Explicit Cursor):显式游标需要定义声明,在使⽤前要打开和获取,使⽤完毕后要关闭。
多⽤于返回多⾏的SELECT语句隐式游标(Implicit Cursor):在执⾏⼀个SQL语句时,服务器将⾃动创建⼀个隐式游标,该游标是内存中的⼯作区,存储了执⾏SQL 语句的结果,可通过游标的属性获得SQL的执⾏结果及状态信息。
多⽤于只返回⼀⾏的SQL语句4、隐式游标(ORACLE在创建隐式游标时,默认的游标名为SQL)1)游标的主要属性(显⽰游标、隐式游标)%FOUND 布尔型属性,当SQL语句⾄少影响⼀⾏时为TRUE,否则为FALSE%NOTFOUND 布尔型属性,当SQL语句没有影响的⾏时为TRUE,否则为FALSE%ISOPEN 布尔型属性,当游标已打开时返回TRUE,否则为FALSE(对⽤户⽽⾔,隐式游标永远是false)%ROWCOUNT 数字型属性,返回受到SQL影响的⾏数注意:属性名与游标名之间没有空格。
游标的属性只能在PL/SQL块中使⽤,⽽不能在SQL语句中使⽤例1 将PRODUCTS表中类型为1的所有产品的单价打9折,并显⽰该更新所影响的⾏数.BEGINUPDATE productsSET unitprice=unitprice*0.9WHERE categoryid=1;IF SQL%FOUND THENdbms_output.put_line(‘更新了’||SQL%ROWCOUNT||’条记录’);ELSEdbms_output.put_line(‘没有更新记录’);END IF;END;5、显式游标1)定义游标在使⽤显⽰游标之前,必须先在声明部分定义游标,其定义语法如下:CURSOR cursor_name[(parameter,…)]IS select_statement;说明:参数parameter形式如下:para_name [IN] data_type [:=|DEFAULT value](2)打开游标当打开游标时,ORACLE会执⾏游标所对应的SELECT语句,并将结果存放到结果集,其定义语法如下:OPEN cursor_name[(parameter,…)];(3)提取数据语法如下:FETCH cursor_name INTO variable[,…];说明:对游标第⼀次执⾏FETCH语句时,它将⼯作区中的第⼀条记录赋给赋给变量,并使⼯作区内的指针指向下⼀条记录。
oracle游标详解
游标(CURSOR)是ORACLE系统在内存中开辟的一个工作区,在其中存放SELECT语句返回的查询结果.这个查询结果既可以是零记录,单条记录,也可以是多条记录.在游标所定义的工作区中,存在着一个指针(POINTER),在初始状态它指向查询结果的首记录.SQL是用于访问ORACLE数据库的语言,PL/SQL扩展和加强了SQL的功能,它同时引入了更强的程序逻辑。
PL/SQL支持DML命令和SQL的事务控制语句。
DDL在PL/SQL中不被支持,这就意味作在PL/SQL程序块中不能创建表或其他任何对象。
较好的PL/SQL程序设计是在PL/SQL块中使用象DBMS_SQL这样的内建包或执行EXECUTE IMMEDIATE命令建立动态SQL来执行DDL命令,PL/SQL编译器保证对象引用以及用户的权限。
下面我们将讨论各种用于访问ORACLE数据库的DDL和TCL语句。
查询SELECT语句用于从数据库中查询数据,当在PL/SQL中使用SELECT语句时,要与INTO 子句一起使用,查询的返回值被赋予INTO子句中的变量,变量的声明是在DELCARE中。
SELECT INTO语法如下:SELECT [DISTICT|ALL]{*|column[,column,...]}INTO (variable[,variable,...] |record)FROM {table|(sub-query)}[alias]WHERE............PL/SQL中SELECT语句只返回一行数据。
如果超过一行数据,那么就要使用显式游标(对游标的讨论我们将在后面进行),INTO子句中要有与SELECT子句中相同列数量的变量。
INTO子句中也可以是记录变量。
%TYPE属性在PL/SQL中可以将变量和常量声明为内建或用户定义的数据类型,以引用一个列名,同时继承他的数据类型和大小。
这种动态赋值方法是非常有用的,比如变量引用的列的数据类型和大小改变了,如果使用了%TYPE,那么用户就不必修改代码,否则就必须修改代码。
Oracle中游标的用法
Oracle中游标的⽤法什么是游标?①从表中检索出结果集,从中每次指向⼀条记录进⾏交互的机制。
②关系数据库中的操作是在完整的⾏集合上执⾏的。
由 SELECT 语句返回的⾏集合包括满⾜该语句的 WHERE ⼦句所列条件的所有⾏。
由该语句返回完整的⾏集合叫做结果集。
应⽤程序,尤其是互动和在线应⽤程序,把完整的结果集作为⼀个单元处理并不总是有效的。
这些应⽤程序需要⼀种机制来⼀次处理⼀⾏或连续的⼏⾏。
⽽游标是对提供这⼀机制的结果集的扩展。
游标是通过游标库来实现的。
游标库是常常作为数据库系统或数据访问 API 的⼀部分⽽得以实现的软件,⽤来管理从数据源返回的数据的属性(结果集)。
这些属性包括并发管理、在结果集中的位置、返回的⾏数,以及是否能够在结果集中向前和/或向后移动(可滚动性)。
游标跟踪结果集中的位置,并允许对结果集逐⾏执⾏多个操作,在这个过程中可能返回⾄原始表,也可能不返回⾄原始表。
换句话说,游标从概念上讲基于数据库的表返回结果集。
由于它指⽰结果集中的当前位置,就像计算机屏幕上的光标指⽰当前位置⼀样,“游标”由此得名。
游标有什么作⽤?①指定结果集中特定⾏的位置。
②基于当前的结果集位置检索⼀⾏或连续的⼏⾏。
③在结果集的当前位置修改⾏中的数据。
④对其他⽤户所做的数据更改定义不同的敏感性级别。
⑤可以以编程的⽅式访问数据库。
⼀、游标:1、概念:游标的本质是⼀个结果集resultset,主要⽤来临时存储从数据库中提取出来的数据块。
⼆、游标的分类:1、显式游标:由⽤户定义,需要的操作:定义游标、打开游标、提取数据、关闭游标,主要⽤于对查询语句的处理。
属性:%FOUND %NOTFOUND %ISOPEN %ROWCOUNTExample:打印emp表的员⼯信息DECLARECURSOR emp_cursor IS SELECT empno,ename,job FROM emp;v_empno emp.empno%TYPE;v_name emp.ename%TYPE;v_job emp.job%TYPE;BEGINOPEN emp_cursor;LOOPFETCH emp_cursor INTO v_empno,v_name,v_job;DBMS_OUTPUT.PUT_LINE('员⼯号为:'||v_empno||'姓名是'||v_name||'职位:'||v_job);EXIT WHEN emp_cursor%NOTFOUND;END LOOP;CLOSE emp_cursor;END;这⾥严格按照显⽰游标的书写规则:DECLARE emp_cursor定义游标OPEN emp_cursor打开游标FETCH emp_cursor INTO...提取数据CLOSE emp_cursor关闭游标,因为提取出来的数据属于多⾏,所以通过loop循环打印即可。
ORACLE中的游标
隐式游标
SQL> SET SERVEROUTPUT ON SQL> DECLARE v_TOYID TOYS.ID%type := '&TOYID'; v_TOYNAME %Type := '&TOYNAME'; BEGIN UPDATE TOYS SET NAME = v_TOYNAME WHERE toyid=v_TOYID; IF SQL%NOTFOUND THEN DBMS_OUTPUT.PUT_LINE('编号未找到。'); 编号未找到。 编号未找到 ELSE DBMS_OUTPUT.PUT_LINE(‘表已更新 表已更新'); 表已更新 END IF; 语句不影响任何行, 如果 DML 语句不影响任何行,则返回 END; True /
显示游标属性
%ROWCOUNT – SQL 语句影响的行数 即返回游标所找到的数据行数 返回一个 语句影响的行数,即返回游标所找到的数据行数 即返回游标所找到的数据行数(返回一个 整数)。示例如下: 整数 。示例如下: LOOP FETCH c1 INTO my_ename, my_depton; IF c1%ROWCOUNT > 10 THEN ... END IF; ... END LOOP; %ISOPEN - 游标是否打开,即游标打开为 游标是否打开,即游标打开为TRUE,反之则为 反之则为FALSE。示例如下: 反之则为 。示例如下: IF c1%ISOPEN THEN ——如果游标打开,则执行相应操作 如果游标打开, 如果游标打开 ... ELSE ——如果游标未打开,则打开游标 如果游标未打开, 如果游标未打开 OPEN c1; END IF;
游标的分类
oracle 游标 参数
oracle 游标参数摘要:1.Oracle 游标的概念和作用2.Oracle 游标的种类3.Oracle 游标的使用方式4.Oracle 游标的参数5.Oracle 游标参数的应用实例正文:1.Oracle 游标的概念和作用Oracle 游标是Oracle 数据库中一种用于遍历和处理查询结果的机制。
游标允许用户在记录行间移动,同时对记录执行插入、更新和删除操作。
游标在存储过程、触发器和函数中使用得较多,它们提供了一种灵活的方式来处理查询结果集。
2.Oracle 游标的种类Oracle 游标主要有三种类型:(1)ROW_NUMBER:为每一行记录分配一个唯一的数字,方便遍历和处理记录。
(2)ROWID:表示记录在结果集中的物理位置,通常用于快速定位记录。
(3)KEY_SET:用于遍历结果集中的每一行,但不提供记录的物理位置信息。
3.Oracle 游标的使用方式要使用Oracle 游标,需要先创建一个游标,然后使用OPEN 语句打开游标。
接下来,可以使用FETCH 语句获取游标中的数据,使用CLOSE 语句关闭游标。
以下是一个简单的游标使用示例:```CREATE CURSOR my_cursor ISSELECT * FROM my_table;OPEN my_cursor;FETCH FROM my_cursor INTO variables;CLOSE my_cursor;```4.Oracle 游标的参数Oracle 游标参数是在创建游标时定义的,用于控制游标的行为。
以下是一些常用的游标参数:(1)游标名称:用于唯一标识游标。
(2)查询语句:用于定义游标的结果集。
(3)游标类型:用于指定游标的类型,如ROW_NUMBER、ROWID 或KEY_SET。
(4)游标选项:用于控制游标的一些特定行为,如自动提交、滚动游标等。
5.Oracle 游标参数的应用实例假设有一个名为“employees”的表,包含以下列:id、name、salary。
oracle高级用法
oracle高级用法Oracle是一个功能强大的关系型数据库管理系统,广泛应用于企业级应用程序和数据仓库。
除了基本的数据库操作(如表的创建、插入、查询和更新),Oracle还提供了许多高级用法和功能,以帮助开发人员更有效地管理和操作数据库。
在本文中,我将介绍一些Oracle的高级用法。
1. 存储过程和函数:Oracle允许开发人员创建复杂的存储过程和函数,这些过程和函数可以像普通SQL语句一样在数据库中执行。
存储过程和函数可以接受参数,并返回结果。
它们可以包含流程控制语句、循环和条件语句,以便实现复杂的业务逻辑。
存储过程和函数可以被其他程序调用,也可以在数据库触发器和作业中使用。
2. 游标:Oracle提供了游标的概念,用于处理查询结果集。
游标可以在存储过程和函数中声明,并用于遍历和处理多行结果集。
开发人员可以使用游标在程序中逐行处理结果集,实现更复杂的业务逻辑。
3.触发器:触发器是数据库中的一种特殊对象,可以在特定的数据库操作(如插入、更新、删除)发生时自动执行一些操作。
触发器可以用于实现数据的自动化验证和补齐,以及复杂的业务规则的实施。
4. 索引:索引是一种数据结构,用于加速数据检索。
Oracle允许开发人员在表的列上创建索引,以便更快地执行查询操作。
索引可以根据特定的列值进行排序,并提供快速的访问方式。
开发人员应该根据查询的需求和频率来判断哪些列应该创建索引,以避免过多的索引影响性能。
5. 分区:分区是一种将大表分解为小块并存储在不同存储设备上的技术。
Oracle允许开发人员在表级别上进行分区,以便更好地管理和查询大型数据集。
通过对表进行分区,可以提高查询性能、减少存储空间占用,并简化数据的维护。
6. 并行查询:Oracle支持并行查询,即将一个查询同时分派给多个处理器来执行,以提高查询的执行速度。
并行查询可以显著减少大型查询的执行时间,提高数据库的整体性能。
开发人员可以通过调整查询的并行度参数来控制并行查询的执行方式。
oracle中游标的用法
Oracle中游标的用法1. 引言在Oracle数据库中,游标(Cursor)是一种用于处理查询结果集的机制。
通过使用游标,我们可以在应用程序中对查询结果集进行遍历、操作和管理。
本文将详细介绍Oracle中游标的用法,包括游标的定义、声明、打开、关闭以及使用游标进行数据检索和更新等操作。
2. 游标的定义与声明在Oracle数据库中,我们可以使用DECLARE语句来定义和声明游标。
以下是一个简单的示例:DECLARECURSOR cursor_name IS SELECT column1, column2 FROM table_name;在上述示例中,cursor_name是游标的名称,SELECT column1, column2 FROMtable_name是一个SQL查询语句,它指定了要从哪个表中检索数据。
3. 游标的打开与关闭在使用游标之前,我们需要先打开它。
要打开一个游标,我们可以使用OPEN语句。
以下是一个示例:OPEN cursor_name;当我们完成对游标的操作后,需要关闭它以释放资源。
要关闭一个游标,我们可以使用CLOSE语句。
以下是一个示例:CLOSE cursor_name;注意,在关闭一个已经被打开的游标之前,我们必须先确保已经完成了对其所有操作。
4. 使用游标进行数据检索一旦我们定义、声明并打开了一个游标,我们就可以使用它来检索数据。
在Oracle中,我们可以使用FETCH语句对游标中的数据进行逐行检索。
以下是一个示例:FETCH cursor_name INTO variable1, variable2;在上述示例中,variable1和variable2是用于接收查询结果的变量。
当我们需要遍历整个结果集时,可以使用循环结构来连续地检索数据。
以下是一个示例:DECLARECURSOR cursor_name IS SELECT column1, column2 FROM table_name;variable1 table_name.column1%TYPE;variable2 table_name.column2%TYPE;BEGINOPEN cursor_name;LOOPFETCH cursor_name INTO variable1, variable2;EXIT WHEN cursor_name%NOTFOUND; -- 当没有更多的数据可检索时退出循环-- 在这里执行对查询结果的操作END LOOP;CLOSE cursor_name;END;在上述示例中,我们使用了一个无限循环,并在每次迭代中通过FETCH语句将查询结果赋值给变量。
Oracle游标详解
游标详解说明:本例中,通过SQL%FOUND属性判断修改是否成功,并给出相应信息。
显式游标游标的定义和操作游标的使用分成以下4个步骤。
1.声明游标在DECLEAR部分按以下格式声明游标:CURSOR 游标名[(参数1 数据类型[,参数2 数据类型...])]IS SELECT语句;参数是可选部分,所定义的参数可以出现在SELECT语句的WHERE子句中。
如果定义了参数,则必须在打开游标时传递相应的实际参数。
SELECT语句是对表或视图的查询语句,甚至也可以是联合查询。
可以带WHERE条件、ORDER BY或GROUP BY等子句,但不能使用INTO子句。
在SELECT语句中可以使用在定义游标之前定义的变量。
2.打开游标在可执行部分,按以下格式打开游标:OPEN 游标名[(实际参数1[,实际参数2...])];打开游标时,SELECT语句的查询结果就被传送到了游标工作区。
3.提取数据在可执行部分,按以下格式将游标工作区中的数据取到变量中。
提取操作必须在打开游标之后进行。
FETCH 游标名INTO 变量名1[,变量名2...];或FETCH 游标名INTO 记录变量;游标打开后有一个指针指向数据区,FETCH语句一次返回指针所指的一行数据,要返回多行需重复执行,可以使用循环语句来实现。
控制循环可以通过判断游标的属性来进行。
下面对这两种格式进行说明:第一种格式中的变量名是用来从游标中接收数据的变量,需要事先定义。
变量的个数和类型应与SELECT语句中的字段变量的个数和类型一致。
第二种格式一次将一行数据取到记录变量中,需要使用%ROWTYPE事先定义记录变量,这种形式使用起来比较方便,不必分别定义和使用多个变量。
定义记录变量的方法如下:说明:本例使用emp_cursor%ISOPEN判断游标是否打开;使用emp_cursor%ROWCOUNT获得到目前为止FETCH语句返回的数据行数并输出;使用循环来获取数据,在循环体中使用FETCH语句;使用emp_cursor%NOTFOUND判断FETCH 语句是否成功执行,当FETCH语句失败时说明数据已经取完,退出循环。
oracle open cursor参数
oracle open cursor参数(原创版)目录1.Oracle 概述2.Oracle 中的游标3.Oracle Open Cursor 参数4.Open Cursor 参数的使用方法5.示例正文1.Oracle 概述Oracle 是一款广泛使用的关系型数据库管理系统,它提供了丰富的功能和高效的性能,被众多企业和组织用于存储和管理数据。
在 Oracle 中,游标是一种用于从数据库中检索数据的机制,通过游标可以方便地在记录行间移动,同时对记录执行插入、更新和删除操作。
2.Oracle 中的游标在 Oracle 中,游标分为三种:OPEN CURSOR、FETCH CURSOR 和关闭游标。
其中,OPEN CURSOR 用于定义一个游标,FETCH CURSOR 用于执行 SQL 查询并将结果存储到游标中,关闭游标用于释放游标资源。
游标是客户端和服务器之间的一个逻辑连接,客户端通过游标发送执行请求,服务器通过游标返回执行结果。
3.Oracle Open Cursor 参数Oracle Open Cursor 参数是用于定义游标的关键字,它包括以下几个参数:- CURSOR:定义一个游标- IS:用于指定游标是否为输入输出游标,取值为 TRUE 或 FALSE - NAME:定义游标的名称,可以是字符串或符号常量- POSITION:定义游标的起始位置,取值范围为 1 到%s,默认为 1 - ROWS:定义游标的行数,取值范围为 0 到%s,默认为 0- COLUMNS:定义游标的列数,取值范围为 0 到%s,默认为 0- STATISTICS:定义是否返回游标统计信息,取值为 TRUE 或 FALSE,默认为 FALSE- NO_NOTIFY:定义是否接收游标通知,取值为 TRUE 或 FALSE,默认为 FALSE4.Open Cursor 参数的使用方法使用 Open Cursor 参数定义游标需要按照以下语法进行:```OPEN CURSOR CURSOR_NAME(IS INPUT_OUTPUT, POSITION, ROWS, COLUMNS, STATISTICS,NO_NOTIFY)RETURNING (column1, column2,...);```其中,CURSOR_NAME 为游标名称,IS、POSITION、ROWS、COLUMNS、STATISTICS 和 NO_NOTIFY 为可选参数,根据需要进行设置。
oracle游标
oracle游标游标1初识游标概念oracle在执⾏sql语句时,给sql语句分配了⼀个缓冲区游标是指向缓冲区的⼀个地址缓冲区中包含了sql语句的运⾏结果其中对于select语句,保存的是查询结果对于update,delete,insert语句,缓冲区保存的是影响的数据库条数游标的分类显式游标和隐式游标显式游标使⽤cursor语句显式定义的游标,游标被定义之后,需要打开并提取游标隐式游标由oracle为每⼀个不属于显式游标的sql dml语句都创建⼀个隐式的游标由于隐式游标没有名字,因此叫做sql游标简单使⽤游标declare--声明⼀个游标指向emp表的所有数据cursor cur is select * from emp;--声明⼀个变量保存游标的记录v emp%rowtype;begin--打开游标open cur;--访问游标中的数据fetch cur into v;--打印变量v的ename值dbms_output.put_line(v.ename);--访问游标中的数据fetch cur into v;--打印变量v的ename值dbms_output.put_line(v.ename);--关闭游标close cur;end;输出juneS_HH%GGH2游标的属性2.1%isopen属性判断对应的游标变量是否打开,如果游标变量打开,则返回true,否则返回false declare--定义⼀个游标指向emp表中所有数据cursor emp_cur is select * from emp;begin--显⽰游标状态if emp_cur%isopen thendbms_output.put_line('1游标已经打开');elsedbms_output.put_line('1游标没有打开');end if;--如果游标没有打开,则打开if not emp_cur%isopen thenopen emp_cur;end if;--显⽰游标状态if emp_cur%isopen thendbms_output.put_line('2游标已经打开');elsedbms_output.put_line('2游标没有打开');end if;close emp_cur;end;输出1游标没有打开2游标已经打开通过代码可以看到,在调⽤open⽅法显式打开游标之前,游标的%isopen属性为false,调⽤open打开游标之后,%isopen属性为true2.2%found检查是否从结果集中提取到了数据在调⽤fetch语句获取数据之前,%found会产⽣null值,⽽此后每取得⼀条数据,其值会为true如果最后⼀次取得数据失败,其值会变为falsev emp_cur%rowtype;begin--打开游标open emp_cur;--在使⽤fetch提取游标数据之前,值为nullif emp_cur%found is null thendbms_output.put_line('%found属性为null');end if;--循环提取游标数据loop--使⽤fetch...into...语句提取游标数据fetch emp_cur into v;--每循环⼀次判断%found属性值,如果该值为false,表⽰提取完成,退出循环exit when not emp_cur%found;--获取表中所有员⼯编号dbms_output.put_line(v.empno);end loop;close emp_cur;end;输出%found属性为null9123777773697499752175667654...2.3%notfound属性该属性与%found属性相反,当没有从游标中提取数据时,该属性返回true,否则返回false 在loop循环内部,每fetch⼀次游标数据后,都会使⽤exit when判断%notfound属性的值是否为true如果是true,则表⽰游标已⽆任何数据可以提取v emp_cur%rowtype;begin--打开游标open emp_cur;--在使⽤fetch提取游标数据之前,值为nullif emp_cur%found is null thendbms_output.put_line('%found属性为null');end if;--循环提取游标数据loop--使⽤fetch...into...语句提取游标数据fetch emp_cur into v;--每循环⼀次判断%found属性值,如果该值为false,表⽰提取完成,退出循环 exit when emp_cur%notfound;--获取表中所有员⼯编号dbms_output.put_line(v.empno);end loop;close emp_cur;end;输出%found属性为null9123777773697499752175662.4%rowcount属性返回到⽬前为⽌已经从游标中取出的记录的⾏数当游标被打开时,%rowcount值为0,每取到⼀条数据,%rowcount的值就加1declare--声明⼀个游标变量cursor emp_cur is select * from emp;--声明⼀个变量,存放游标记录v emp_cur%rowtype;begin--打开游标open emp_cur;--遍历循环loop--提取游标数据fetch emp_cur into v;--退出循环条件exit when emp_cur%notfound;--打印%rowcount值dbms_output.put_line('当前已提取'||emp_cur%rowcount);end loop;close emp_cur;end;当前已提取1当前已提取2当前已提取3...当前已提取14当前已提取15当前已提取163游标参数3.1单个参数语法cursor 游标(参数名数据类型 [default 默认值])is select语句declare--定义⼀个游标cursor cur_emp(dno number) is select * from emp where deptno=dno; --定义⼀个变量,保存游标记录v cur_emp%rowtype;begin--打开游标,并传值open cur_emp(10);loop--将游标中的⼀条记录保存到变量中fetch cur_emp into v;--判断退出条件exit when cur_emp%notfound;--打印变量的ename和deptno值dbms_output.put_line(v.empno||v.deptno);end loop;close cur_emp;end;输出9123107782107839107934103.2多个参数--定义⼀个游标cursor cur_emp(dno number default 20,vsal number) is select * from emp where deptno=dno and sal<vsal; --定义⼀个变量,保存游标记录v cur_emp%rowtype;begin--打开游标,并传值open cur_emp(30,1000);loop--将游标中的⼀条记录保存到变量中fetch cur_emp into v;--判断退出条件exit when cur_emp%notfound;--打印变量的ename和deptno值dbms_output.put_line(v.empno||v.deptno||v.sal);end loop;close cur_emp;end;输出7900309503.3传变量declare--定义⼀个游标cursor cur_emp(dno number) is select * from emp where deptno=dno;--定义⼀个变量,保存游标记录v cur_emp%rowtype;--获取⽤户输⼊部门vdeno dept.deptno%type:=&部门编号;begin--打开游标,并传值open cur_emp(vdeno);loop--将游标中的⼀条记录保存到变量中fetch cur_emp into v;--判断退出条件exit when cur_emp%notfound;--打印变量的ename和deptno值dbms_output.put_line(v.empno||v.deptno);end loop;close cur_emp;end;弹窗输⼊30,输出7499307521307654307698307844307900304游标遍历列出每个员⼯的姓名、部门名称并编程显⽰第10个到第20个记录4.1loop遍历游标--声明⼀个游标变量cursor cur_ed is select a.ename,b.dname from emp a,dept b where a.deptno=b.deptno; --声明⼀个变量保存游标的记录v cur_ed%rowtype;begin--打开游标open cur_ed;--遍历游标loop--访问游标中的数据fetch cur_ed into v;--退出loop循环条件exit when cur_ed%notfound;--根据条件,输出到屏幕if cur_ed%rowcount between 10 and 20 thendbms_output.put_line(v.ename||','||v.dname);end if;end loop;--关闭游标close cur_ed;end;输出SCOTT,RESEARCHKING,ACCOUNTINGTURNER,SALESADAMS,RESEARCHJAMES,SALESFORD,RESEARCHMILLER,ACCOUNTING4.2while循环declare--声明⼀个游标cursor cur_ed is select a.ename,b.dname from emp a,dept b where a.deptno=b.deptno; --声明⼀个变量,保存游标的记录v cur_ed%rowtype;begin--打开游标open cur_ed;--执⾏fetch into语句,让游标指向第⼀条数据fetch cur_ed into v;--根据条件进⼊循环while cur_ed%found loop--打印变量的值if cur_ed%rowcount between 10 and 20 thendbms_output.put_line(v.ename||','||v.dname);end if;--让游标指向下⼀条数据fetch cur_ed into v;end loop;--关闭游标close cur_ed;end;输出SCOTT,RESEARCHKING,ACCOUNTINGTURNER,SALESADAMS,RESEARCHJAMES,SALESFORD,RESEARCHMILLER,ACCOUNTING4.3for循环declare--声明⼀个游标变量cursor cur_ed is select a.ename,b.dname from emp a,dept b where a.deptno=b.deptno; beginfor v in cur_ed loop--打印变量的值if cur_ed%rowcount between 10 and 20 thendbms_output.put_line(v.ename||','||v.dname);end if;end loop;end;输出SCOTT,RESEARCHKING,ACCOUNTINGTURNER,SALESADAMS,RESEARCHJAMES,SALESFORD,RESEARCHMILLER,ACCOUNTING5游标变量前⾯游标的使⽤,发现每定义⼀个游标,就为其绑定⼀个查询语句这种游标称为静态游标游标变量是另⼀种类型的游标,在定义时并不绑定到具体的查询,⽽是可以打开任何类型兼容的查询,灵活性较好5.1语法游标类型的定义type 类型名称 is ref cursor;游标变量的声明变量名类型名;游标变量的使⽤1,打开游标open 游标变量 for select 语句;2,遍历游标fetch 游标变量 into 变量;3,关闭游标close 游标变量;注意:游标变量不能使⽤for循环遍历loopdeclare--定义⼀个游标类型type ctype is ref cursor;--声明⼀个游标变量cur ctype;--声明⼀个变量保存游标中的⼀条记录v dept%rowtype;begin--打开游标open cur for select * from dept;--遍历游标loop--将游标中的数据保存到变量中fetch cur into v;--判断退出条件exit when cur%notfound;--打印变量值dbms_output.put_line(v.deptno||','||v.dname); end loop;--关闭游标close cur;end;输出10,ACCOUNTING20,RESEARCH30,SALES40,OPERATIONSwhiledeclare--声明⼀个游标类型type etype is ref cursor;--声明⼀个游标变量cur etype;--声明⼀个变量保存游标中的⼀条记录v emp%rowtype;begin--打开游标open cur for select * from emp where deptno=20; --fetch into语句将游标指向第⼀条语句fetch cur into v;--遍历游标while cur%found loop--打印变量值dbms_output.put_line(v.deptno||','||v.ename); --循环控制fetch cur into v;end loop;--关闭游标close cur;end;输出20,S_HH%GGH20,SMITH20,JONES20,SCOTT20,ADAMS20,FORD补充隐式游标隐式游标:在执⾏insert、update、delete语句时,oracle给它们分配了⼀个游标,游标名叫sql 可以调⽤游标的属性 %rowcountbeginupdate emp set sal=sal+500 where deptno=30;--打印update语句修改的数据条数dbms_output.put_line(sql%rowcount);rollback;end;输出6。
PLSQL系列培训之二:游标、集合和对象(幻灯说明稿)
PL/SQL系列培训之二:游标、集合和对象游标CURSOR当ORACLE处理每一个SQL语句的时候,它会开辟一块内存空间来存储SQL执行计划、绑定变量等上下文信息。
而游标就是指向这块内存区域的指针。
PL/SQL块通过游标来访问或操作这块内存区域。
CURSOR的两个重要特性:(1)如果是SELECT SQL,可以通过CURSOR来一条一条地获取到查询到的行(2)可以通过对CURSOR命名来持有并操作它。
CURSOR分类:(1)隐式游标:只要有SQL执行,ORACLE都会自动声明一个隐式游标,这个过程对用户来说是不可见的。
(2)显式游标:显式地在PL/SQL块中为查询SQL定义游标。
Implicit Cursor所有DML语句,包括UPDA TE,DELETE,INSERT都有一个隐式游标自动关联。
UPDATE/DELETE的CURSOR明确了SQL将要修改的行INSERT的CURSOR存放了将要存入的数据可以通过’SQL%’来访问最近打开的CURSORBEGINUPDATE tanjie21SET name = 'BB';DBMS_OUTPUT.PUT_LINE(SQL%ROWCOUNT);END;这样来理解隐式游标,在一个会话里将维持一个隐式游标,在执行新的SQL语句时,ORACLE自动进行REOPEN操作。
两个使用隐式游标的场景:(1)SELECT INTO variable_name(2)FOR rec IN (SELECT id, name FROM tanjie21) LOOP ... END LOOP;Explicit Cursor注意显式游标只能关联到SELECT SQL显式游标使用步骤:(1)定义一个游标---- 只是定义一个游标关联到某个SELECT SQL(2)打开这个游标---- 检查WHERE条件里的变量---- 基于变量的值,PL/SQL引擎执行查询操作并得到结果集---- 将游标指针指向结果集的第一行记录(3)从游标中取数并操作---- 取数的两种方式:·FETCH cursor_name INTO variables;·FETCH cursor_name INTO record (呆会集合会讲)---- 注意:(1)一次只能取一条记录(2)每次FETCH之后,游标指针会自动指向下一条记录。
ORACLE中游标和复合数据类型
ORACLE中游标和复合数据类型一.游标简介A.要处理SQL语句,PL/SQL打开一个称作环境区域的工作区B.PL/SQL使用该区域执行SQL语句和存储处理信息C.称作“游标”的PL/SQL结构允许您命名环境区域,访问其信息及在某些情况下控制其处理过程D.查询返回多行时,可以将游标显式地定义为—在查询所返回的首行之外的处理—对当前正在处理的行进行跟踪E.由多行查询返回的行集称作活动集二.游标类型:有两类游标A.隐式游标由Oracle自动定义并打开,用于处理每个SQL语句最近打开的环境区域被称为“SQL%”游标B.显式游标如果查询返回多行,则可定义显式游标来对当前正在处理的行进行跟踪三.游标功能A.游标名是一个未声明的标识符,仅用于引用查询B.不能对游标赋值,也不能在表达式中使用游标名C.显式游标可以有参数D.游标参数可以出现在查询中常量出现的任何位置上E.可以将游标参数初始化为默认值F.可以将实参的不同值传递到游标,按需要采用或替换默认值G.游标参数的范围对于游标来讲是局部变量H.当游标为OPENED时,游标参数的值可以用于相关的查询四.定义游标:可以通过在PL/SQL程序块的声明部分命名游标或将它与某个查询关联来定义一个游标:CURSORIS;CURSORemp_curISSELECTempno,ename,job,alFROMemp;五.操纵游标A.可以使用下列语句操纵游标:⑴.OPEN,⑵.FETCH,⑶.CLOSEB.在使用OPEN、CLOSE或FETCH语句引用这些语句之前必须对游标进行声明1.OPEN语句A.初始化或打开游标B.在查询返回任何行之前必须打开游标C.打开游标将执行查询并识别活动集合:OPENOPENemp_cur;2.FETCH语句A.一次只能在一个活动集合中检索行B.可以重复执行,直到检索到了所有行FETCHINTOvar1,…,varN;ORFETCHINTOrecord_variable;FETCHemp_curINTOmrec;3.CLOSE语句A.关闭游标并让活动集合成为未定义内容:CLOSE;CLOSEemp_cur;B.只要游标关闭,可以通过使用OPEN语句重新打开它六.显式游标的属性:每个游标有四个属性可以用于访问游标的环境区域–%NOTFOUNDA.如果因为没有多行而使最后的FETCH失败,则判定为TRUEB.如果最后的FETCH返回一行,则判定为FALSE–%FOUNDA.如果最后的FETCH返回一行,则判定为TRUEB.如果因为没有多行而使最后的FETCH失败,则判定为FALSE–%ROWCOUNTA.返回当前从活动集合获取的行数–%ISOPENA.如果打开显示游标,则判定为TRUEB.如果关闭显示游标,则判定为FALSEB.要使用这些属性,只要简单地将它们添加到游标名后即可IFemp_cur%ISOPENTHENFETCHemp_curINTOm_rec;IFemp_cur%FOUNDTHENmr_no:=emp_cur%ROWCOUNT;ENDIF;ELSEOPENemp_cur;ENDIF;七.游标FOR循环A.将它的循环索引声明为%ROWTYPE的记录B.隐式地打开游标C.从活动集反复获取行的值并传送到记录中的字段D.在处理完所有行,并且循环退出时,隐式地关闭游标E.为满足与游标名相关的查询的每一行执行循环结构中的语句F.游标FOR循环用于简化代码编写DECLARECURSORemp_curISSELECTempno,ename,job,alFROMemp;BEGINFORmrecINemp_curLOOPINSERTINTOtempVALUES(mrec.empno,mrec.ename,mrec.job,mrec.al);ENDLOOP;END;八.参数化的游标A.游标也可接收参数B.这些参数仅可用于游标的SELECT语句的输入C.游标参数可以在查询中常量出现的任何位置上出现D.可以在OPEN语句或游标FOR循环中提供参数值DECLARECURSORemp_curISSELECTempno,ename,job,alFROMempWHEREjob=pjob;mjobemp.job%TYP E;BEGINmjob:=‘&job’;FORmrecINemp_cur(mjob)LOOPtatement;ENDLOOP;END;九.游标FORUPDATEOF和CURRENTOFA.CURRENTOF子句用于在UPDATE或DELETE语句中以引用游标当前行B.必须使用FORUPDATEOF子句声明游标,并在一行上打开并定位C.如果游标没有打开,则CURRENTOF子句将产生错误D.如果游标已经打开,但没有处理FETCH或最后一个FETCH没有返回任何行,则将产生预定义例外NO_DATA_FOUNDDECLARECURSORemp_curISSELECTempno,ename,job,alFROMempWHEREjob=pjobFORUPDATEOFal;BEGINFORmrecINemp_curLOOPUPDATEempSETal=al某0.15WHERECURRENTOFemp_cur;ENDLOOP;END;隐式游标的属性(1)虽然OPEN、CLOSE和FETCH语句不能用于操作SQL%游标,但属性可以用于访问游标的环境区域(2)在游标自动打开之前,属性判定为NULL(3)下列四个游标属性可以用于访问SQL%游标的环境区域A.SQL%NOTFOUND:●如果INSERT,UPDATE或DELETE语句没有影响行,则判定为TRUE,否则判定为FALSE。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
OOP的概念
24
使用对象数据类型的优点: 更容易与Java、C++编写的对象应用程序 交互。 获取便捷。一次对象类型请求就可以从多 个关系表中获取信息,通过一次网络往复 即可返回。 可以把对象数据类型理解为在OOP语言中的 类。创建一个对象数据类型相当于创建一个 类,以后我们可以实例化,继承等等
3.0
嵌套表
嵌套表和联合数组类似,唯一不同是没有 INDEX BY binary_integer子句 嵌套表使用前需要初始化
DECLARE TYPE stutab IS TABLE OF varchar2(20); stu stutab := stutab('张三', '李四', '王五'); BEGIN for i in 1..3 loop dbms_output.put_line(stu(i)); end loop; END;
16
3.0
集合
集合类似于其他第3代语言中使用的数组 PL/SQL语言提供了3种不同的集合类型 联合数组(也称为索引表) 嵌套表 可变数组
17
3.0
联合数组
18
联合是具有Oracle的数据类型或用户自定义 类型的一维体 声明联合数组的语法格式
TYPE table_type IS TABLE OF type INDEX BY binary_integer ;
13
3.0
游标变量
声明一个引用游标类型
--强类型游标(指定返回类型) TYPE dept_cur IS REF CURSOR RETURN dept%rowtype; --弱类型游标(没有返回类型) TYPE mycur IS REF CURSOR ;
14
3.0
游标变量
声明游标变量
DECLARE TYPE dept_cur IS REF CURSOR RETURN dept%rowtype; cur1 dept_cur ; /*声明游标变量*/
3.0
游标
PL/SQL用游标(cursor)来管理 select语句 用来获取,定位结果集中的数据的指示器. 游标分类 静态游标
显式游标(explicit cursor) 显式游标 隐式游标( 隐式游标(implicit cursor) )
4
游标变量ቤተ መጻሕፍቲ ባይዱ
3.0
显式游标
显式游标的使用步骤 声明游标 声明游标(declare) 打开游标 打开游标(open) 读取数据 关闭游标 关闭游标(close)
3.0
联合数组
联合数组示例
19
DECLARE TYPE emp_name IS TABLE OF varchar2(10); /*声明类型*/ INDEX BY binary_integer; names emp_name; /*声明变量*/ BEGIN names(1) := '张飞' ; names(2) := '关羽' ; END
20
3.0
可变数组
可变数组的语法格式如下:
TYPE type_name IS VARRAY | VARYING ARRAY (max_size) OF element_type [NOT NULL]
21
3.0
可变数组
可变数组也需要初始化。需要注意赋值的 数量必须保证不大于可变数组的最大上限
DECLARE TYPE montharr IS VARRAY(12) OF varchar2(10); months montharr := montharr('January','February','March'); BEGIN months.extend(2); /*给months可变数组增加两个元素*/ months(4) := 'April'; months(5) := 'June'; FOR i IN 1..5 LOOP dbms_output.put_line(months(i)); END LOOP; END;
3.0
显式游标
读取数据
FETCH cursor_name [INTO variable_name,…n];
8
示例
BEGIN OPEN emp_cur ; FETCH emp_cur INTO name, job, sal ; /*从结果集中提取一行数据*/ WHILE emp_cur%FOUND LOOP dbms_output.put_line ( name || ' ' || job || ' ' || sal ) ; FETCH emp_cur INTO name, job, sal ; /*在循环中每次提取一行数据*/ END LOOP; CLOSE emp_cur ; END;
3.0
隐式游标
在PL/SQL程序段中使用SELECT语句进行 操作,PL/SQL语言会隐含地处理游标定义 示例:
DECLARE name varchar2(10); BEGIN select ename into name from emp where empno=7934; dbms_output.put_line( name ); END;
3.0
总结
25
1. 显式游标用于处理返回一到多行结果集的select语 句,显式游标首先要声明,在使用前要打开,使 用完要关闭。 2. 隐式游标即简单地编码select语句。当select语句 预计只返回一行时使用隐式游标。 3. 使用游标变量需要先声明引用游标类型,再定义 该种类型的游标变量。它不与特定的查询绑定在 一起,而是可以动态地打开不同的查询。处理结 果集的方式与显式游标基本相同。 4. 集合包括:联合数组、嵌套表、可变数组,它们 都是以数组的方式操纵数据,可以使用集合在 PL/SQL中完成一些复杂的操作。 5. Oracle 数据库是一种对象关系型数据库,它在关 系型数据库的基础上加入了面向对象的概念 3.0
15
打开游标变量
OPEN cur1 FOR select * from dept where deptno=10;
3.0
游标变量
示例
DECLARE TYPE dept_cur IS REF CURSOR RETURN dept%rowtype; cur1 dept_cur ; dept1 dept%rowtype; BEGIN OPEN cur1 FOR select * from dept where deptno=10; FETCH cur1 INTO dept1; dbms_output.put_line(dept1.deptno||' '||dept1.dname||' '||dept1.loc); OPEN cur1 FOR select * from dept where dname='SALES'; FETCH cur1 INTO dept1; dbms_output.put_line(dept1.deptno||' '||dept1.dname||' '||dept1.loc); CLOSE cur1; END;
11
3.0
隐式游标
使用隐式游标要注意以下几点 每个隐式游标必须有一个INTO INTO接受的变量类型要与列表的一致 隐式游标一次仅能返回一行数据,使用 时必须检查异常。最常见的异常有 “no_data_found”和“too_many_rows”
12
3.0
游标变量
游标变量是动态的,它不与特定的查询绑 定在一起。可以为任何兼容的查询打开游 标变量,从而提高更好的灵活性。 创建游标变量有两个步骤: 定义 REF CURSOR 类型,即引用游标 类型 声明这种类型的游标变量
22
3.0
OOP的概念
23
自Oracle9i以来,Oracle不再是单纯的关系 数据库管理系统了,它在关系数据库模型的 基础上,添加了一系列面向对象的特性,其 主要目的是把用户类型直接映射到数据库的 类型,从而方便编程。 Oracle面向对象的最基本元素是它的对象类 型,也就是Type Oracle中与面向对象技术相关的数据类型主 要有:对象类型,可变数组,嵌套表,对象 表,对象视图等
第二章
游标、集合、和OOP的概念
3.0
2010-8-15 威迅教育开发部监制
目标
1. 理解游标、集合的概念和作用 2. 掌握在PL/SQL中游标的基本用法 3. 了解Oracle数据库中OOP的基本概念
2
3.0
3
1. 2. 3. 4.
找出最高工资的编号,更新他的工资为70%. 输出姓名,原来工资,现在工资. Rs.next() st()
5
3.0
显式游标
声明游标
CURSOR cursor_name IS select_statement
6
示例
DECLARE CURSOR emp_cur IS select ename,job,sal from emp;
3.0
显式游标
打开游标
OPEN cursor_name;
7
示例
...... BEGIN OPEN emp_cur ; dbms_output.put_line( emp_cur%ROWCOUNT ); END;
3.0
显式游标
关闭游标
CLOSE cursor_name ;
9
示例
BEGIN …… CLOSE emp_cur ; END;
3.0
显式游标
10
游标的属性 %FOUND 检测当前游标指向的行是否有 数据 %NOTFOUND 与%FOUND相反 %ROWCOUNT 从游标中已提取的总行数 %ISOPEN 检测游标是否已打开