网站大量收购闲置独家精品文档,联系QQ:2885784924

PLSQL入门教程PLSQL入门教程.doc

  1. 1、本文档共6页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
PL/SQL入门教程 1.1 PL/SQL简介   PL/SQL是ORACLE的过程化语言,包括一整套的数据类型、条件结构、循环结构和异常处理结构,PL/SQL可以执行SQL语句,SQL语句中也可以使用PL/SQL函数。 1.2 创建PL/SQL程序块   DECLARE   …   BEGIN   …   EXCEPTION   END; 1.3 PL/SQL数据类型    ?   例子:   DECLARE   ORDER_NO NUMBER(3);   CUST_NAME VARCHAR2(20);   ORDER_DATE DATE;   EMP_NO INTEGER:=25;   PI CONSTANT NUMBER:=3.1416;   BEGIN    NULL;   END; 1.4 处理PL/SQL的异常 1.4.1 PL/SQL的异常   例如:   DECLARE   X NUMBER;   BEGIN   X:= yyyy;--Error Here   EXCEPTION  WHEN VALUE_ERROR THEN   DBMS_OUTPUT.PUT_LINE(EXCEPTION HANDED);   END;   实现技术:   EXCEPTION WHEN first_exception THEN   …   WHEN second_exception THEN   …   WHEN OTHERS THEN?   /*THERS异常处理器必须排在最后,它处理所有没有明确列出的异常。*/   …   END;  1.4.2 预定义异常    ? 1.4.3 自定义异常处理   DECLARE   BAD_ROWID EXCEPTION;   X ROWID;   PRAGMA EXCEPTION_INIT(BAD_ROWID,-01445);   BEGIN   SELECT ROWID INTO X FROM TAB   WHERE ROWNUM=1;   EXCEPTION WHEN BAD_ROWID THEN   DBMS_OUTPUT.PUT_LINE(CANNOT QUERY ROWID FROM THIS VIEW);   END;      注意:-01445 因为PRAGMA EXCEPTION_INIT命令把这个变量(-01455)连接到   这个ORACLE错误,该语句的语法如下:   PRAGMA EXCEPTION_INIT(exception_name, error_number);   其中error_number是负数,因为错误号被认为负数,当定义错误时记住使用负号 1.4.4 自定义异常   异常不一定必须是oracle返回的系统错误,用户可以在自己的应用程序中创   建可触发及可处理的自定义异常   DECLARE   SALARY_CODE VARCHAR2(1);   INVALID_SALARY_CODE EXCEPTION;   BEGIN   SALARY_CODE:=X;   IF SALARY_CODE NOT IN(A, B, C) THEN   RAISE INVALID_SALARY_CODE;   END IF;   EXCEPTION WHEN INVALID_SALARY_CODE THEN   DBMS_OUTPUT.PUT_LINE(INVALID SALARY CODE);   END; 1.5 在PL/SQL中单条记录的查询   在PL/SQL内,有时在没有定义显式光标的情况下需要查询单条记录,并把记录的数据赋给变量。   DECLARE   ln_dno NUMBER;   lvs_dname VARCHAR2(40);   BEGIN   SELECT DEPT_NO,DEPT_NAME     INTO ln_dno,lvs_dname   FROM dept   WHERE DEPT_NO=1;   DBMS_OUTPUT.PUT_LINE(TO_CHAR(ln_dno)||.||lvs_dname);   EXCEPTION WHEN NO_DATA_FOUND THEN   DBMS_OUTPUT.PUT_LINE(NO DATA_FOUND);   WHEN TOO_MANY_ROWS THEN   DBMS_OUTPUT.PUT_LINE(TOO_MANY_ROWS);   END; 1.6 用光标查询多条记录    光标(CURSOR)是指向一个称为上下文相关区的区域的指针,这个区域在服务器的处理过程全局区(PGA)内,当服务器上执行了一个查询后,查询返回的记录集存放在上下文相关区,通过光标上的操作可以把这些记录

文档评论(0)

cduutang + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档