龙盟编程博客 | 无障碍搜索 | 云盘搜索神器
快速搜索
主页 > 数据库类 > Oracle 技术 >

Oracle 游标使用的具体操作方法

时间:2011-04-12 23:18来源:未知 作者:admin 点击:
分享到:
以下的文章主要介绍的是Oracle 游标使用的具体操作方法,如果你是 Oracle 游标实际应用方面的新手,你就可以通过以下的文章对Oracle 游标是如何正确使用的方法有一个更好的了解,以下

以下的文章主要介绍的是Oracle 游标使用的具体操作方法,如果你是Oracle 游标实际应用方面的新手,你就可以通过以下的文章对Oracle 游标是如何正确使用的方法有一个更好的了解,以下就是文章的详细内容的介绍。

Oracle 游标使用大全

我们将讨论各种用于访问Oracle数据库的DDL和TCL语句。

查询

SELECT语句用于从数据库中查询数据,当在PL/SQL中使用SELECT语句时,要与INTO子句一起使用,查询的返回值被赋予INTO子句中的变量,变量的声明是在DELCARE中。SELECT INTO语法如下:

  1. SELECT [DISTICT|ALL]{*|column[,column,...]}  
  2. INTO (variable[,variable,...] |record)  
  3. FROM {table|(sub-query)}[alias]  
  4. WHERE............  

在Oracle 游标使用的过程中,PL/SQL中SELECT语句只返回一行数据。如果超过一行数据,那么就要使用显式游标(对游标的讨论我们将在后面进行),INTO子句中要有与SELECT子句中相同列数量的变量。INTO子句中也可以是记录变量。

%TYPE属性

在PL/SQL中可以将变量和常量声明为内建或用户定义的数据类型,以引用一个列名,同时继承他的数据类型和大小。这种动态赋值方法是非常有用的,比如变量引用的列的数据类型和大小改变了,如果使用了%TYPE,那么用户就不必修改代码,否则就必须修改代码。

例:

  1. v_empno SCOTT.EMP.EMPNO%TYPE;  
  2. v_salary EMP.SALARY%TYPE;  

不但列名可以使用%TYPE,而且变量、游标、记录,或声明的常量都可以使用%TYPE。这对于定义相同数据类型的变量非常有用。

  1. DELCARE  
  2. V_A NUMBER(5):=10;  
  3. V_B V_A%TYPE:=15;  
  4. V_C V_A%TYPE;  
  5. BEGIN  
  6. DBMS_OUTPUT.PUT_LINE  
  7. ('V_A='||V_A||'V_B='||V_B||'V_C='||V_C);  
  8. END  
  9. SQL>/  
  10. V_A=10 V_B=15 V_C=  
  11. PL/SQL procedure successfully completed.  
  12. SQL>  

其他DML语句

其它操作数据的DML语句是:INSERT、UPDATE、DELETE和LOCK TABLE,这些语句在PL/SQL中的语法与在SQL中的语法相同。我们在前面已经讨论过DML语句的使用这里就不再重复了。在DML语句中可以使用任何在DECLARE部分声明的变量,如果是嵌套块,那么要注意变量的作用范围。

例:

  1. CREATE OR REPLACE PROCEDURE FIRE_EMPLOYEE (pempno in number)  
  2. AS  
  3. v_ename EMP.ENAME%TYPE;  
  4. BEGIN  
  5. SELECT ename INTO v_ename  
  6. FROM emp  
  7. WHERE empno=p_empno;  
  8. INSERT INTO FORMER_EMP(EMPNO,ENAME)  
  9. VALUES (p_empno,v_ename);  
  10. DELETE FROM emp   

以上的相关内容就是对Oracle 游标使用的介绍,望你能有所收获。 

精彩图集

赞助商链接