当前位置:七道奇文章资讯数据防范Oracle防范
日期:2011-03-21 00:21:00  来源:本站整理

Oracle数据库游标利用大全[Oracle防范]

赞助商链接



  本文“Oracle数据库游标利用大全[Oracle防范]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:
  查询

  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,那么用户就没必要改正代码,不然就必须改正代码.

 例:

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

  不但列名可以利用%TYPE,并且变量、游标、记录,或声明的常量都可以利用%TYPE.这关于定义相同数据范例的变量非常有效.

DELCARE
V_A NUMBER(5):=10;
V_B V_A%TYPE:=15;
V_C V_A%TYPE;
BEGIN
DBMS_OUTPUT.PUT_LINE
('V_A='||V_A||'V_B='||V_B||'V_C='||V_C);
END

SQL>/
V_A=10 V_B=15 V_C=
PL/SQL procedure successfully completed.

SQL>

  其他DML语句

  别的操作数据的DML语句是:INSERT、UPDATE、DELETE和LOCK TABLE,这些语句在PL/SQL中的语法与在SQL中的语法相同.我们在前面已经谈论过DML语句的利用这里就不再反复了.在DML语句中可以利用任安在DECLARE部份声明的变量,假如是嵌套块,那么要注意变量的作用范围.

  例:

CREATE OR REPLACE PROCEDURE FIRE_EMPLOYEE (pempno in number)
 AS
  v_ename EMP.ENAME%TYPE;
 BEGIN
  SELECT ename INTO v_ename
  FROM emp
  WHERE empno=p_empno;

  INSERT INTO FORMER_EMP(EMPNO,ENAME)
  VALUES (p_empno,v_ename);

  DELETE FROM emp
  WHERE empno=p_empno;

  UPDATE former_emp
  SET date_deleted=SYSDATE
  WHERE empno=p_empno;

  EXCEPTION
   WHEN NO_DATA_FOUND THEN
   DBMS_OUTPUT.PUT_LINE('Employee Number Not Found!');

 END

  DML语句的后果

  当履行一条DML语句后,DML语句的后果保存在四个游标属性中,这些属性用于掌握程序流程大概理解程序的状况.当运行DML语句时,PL/SQL翻开一个内建游标并处理后果,游标是保护查询后果的内存中的一个区域,游标在运行DML语句时翻开,完成后关闭.隐式游标只利用SQL%FOUND,SQL%NOTFOUND,SQL%ROWCOUNT三个属性.SQL%FOUND,SQL%NOTFOUND是布尔值,SQL%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.

  SQL%ROWCOUNT

  在履行任何DML语句之前,SQL%ROWCOUNT的值都是NULL,关于SELECT INTO语句,假如履行成功,SQL%ROWCOUNT的值为1,假如没有成功,SQL%ROWCOUNT的值为0,同时产生一个非常NO_DATA_FOUND.

  SQL%ISOPEN

  SQL%ISOPEN是一个布尔值,假如游标翻开,则为TRUE, 假如游标关闭,则为FALSE.关于隐式游标而言SQL%ISOPEN老是FALSE,这是因为隐式游标在DML语句履行时翻开,完毕时就当即关闭.

  事件掌握语句

  事件是一个工作的逻辑单元可以包含一个或多个DML语句,事物掌握帮忙用户保证数据的一致性.假如事件掌握逻辑单元中的任何一个DML语句失利,那么整个事件都将回滚,在PL/SQL顶用户可以明确地利用COMMIT、ROLLBACK、SAVEPOINT以及SET TRANSACTION语句.

  COMMIT语句终止事件,永久保存数据库的改变,同时释放全部LOCK,ROLLBACK终止现行事件释放全部LOCK,但不保存数据库的任何改变,SAVEPOINT用于设置中间点,当事件调用过量的数据库操作时,中间点是非常有效的,SET TRANSACTION用于设置事件属性,比方read-write和断绝级等.

  显式游标

  当查询返回后果超越一行时,就需求一个显式游标,此时用户不能利用select into语句.PL/SQL管理隐式游标,当查询开始时隐式游标翻开,查询完毕时隐式游标自动关闭.显式游标在PL/SQL块的声明部份声明,在履行部份或非常处理部份翻开,取数据,关闭.下表显示了显式游标和隐式游标的差别:

                 表1 隐式游标和显式游标
隐式游标 显式游标
PL/SQL保护,当履行查询时自动翻开和关闭 在程序中显式定义、翻开、关闭,游标有一个名字.
游标属性前缀是SQL 游标属性的前缀是游标名
属性%ISOPEN老是为FALSE %ISOPEN按照游标的状况肯定值
SELECT语句带有INTO子串,只有一行数据被处理 可以处理多行数据,在程序中设置循环,取出每一行数据.

  以上是“Oracle数据库游标利用大全[Oracle防范]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:

  • SQL Server中利用Linkserver衔接Oracle的办法
  • Oracle数据库网络与安全FAQ精辟堆积
  • Ubuntu 9.10下安装Oracle10g
  • Ubuntu 10.04 下安装Oracle 11g
  • oracle盲注报错语句和oracle提权语句汇总
  • oracle中to_char、to_number、to_date的用法
  • Python模拟Oracle的SQL/PLUS工具的实现办法
  • Oracle数据库访谈之最年青的OCM访谈
  • oracle表数据误删复原
  • Oracle数据库笔记--表空间
  • Oracle数据库树形查询的代码示例
  • oracle中记录和调集
  • 本文地址: 与您的QQ/BBS好友分享!
    • 好的评价 如果您觉得此文章好,就请您
        0%(0)
    • 差的评价 如果您觉得此文章差,就请您
        0%(0)

    文章评论评论内容只代表网友观点,与本站立场无关!

       评论摘要(共 0 条,得分 0 分,平均 0 分) 查看完整评论
    Copyright © 2020-2022 www.xiamiku.com. All Rights Reserved .