数据库应用技术第五章面向过程的SQL扩展.ppt
《数据库应用技术第五章面向过程的SQL扩展.ppt》由会员分享,可在线阅读,更多相关《数据库应用技术第五章面向过程的SQL扩展.ppt(67页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、数据库应用技术第五章面向过程的SQL扩展 Still waters run deep.流静水深流静水深,人静心深人静心深 Where there is life,there is hope。有生命必有希望。有生命必有希望内容概要v5.1服务器端程序v5.2PL/SQL的基本语法v5.3控制流v5.4过程与函数v5.5游标v5.6错误与异常处理v5.7触发器5.1 服务器端程序v存储过程:用户创建,用SQL和其他语言(如PL/SQL)编写的过程或函数,存储在数据库内部,用来完成一个特定的任务。Oracle:PL/SQLMSSQL:Transaction-SQLvPL/SQL:ORACLE对SQL
2、进行扩展的过程式语言,具有通用程序设计语言的绝大部分特性,能够完成较为复杂和完整的功能可以用来编写存储过程。5.1 服务器端程序v存储过程的优点安全:使用创建者权限、调用者不需要了解内部结构,不需要内部权限。性能:v网络开销小,不传送中间结果v节约SQL代码分析时间代码可重用完整性和一致性v特性:可以使用变量、游标、控制结构,具有模块化、数据抽象、信息隐藏、错误处理等特性。5.2 PL/SQL的基本语法v一、块结构v二、变量的定义与使用v三、内嵌SQLPL/SQL的基本规则每条语句可以写在多行每条语句都以;结尾。语句保留字和变量不区分大小写PL/SQL的基本结构-块结构v块结构一个块的语法地位
3、等价于一条语句v块的整体构成DECLAREBEGINEXCEPTIONEND;变量的定义与使用v变量类型简单变量类型v和字段的变量类型相同记录变量类型v一组具有不同类型的变量的集合,类似C中的STRUCT或PASCAL中的RECORD集合变量类型变量的定义与使用v变量声明必须先声明,后使用在declare段声明不允许前向引用一行中只能定义一个变量大小写不敏感变量的定义与使用v简单示例emp_countNUMBER(4);(初始值为NULL)v缺省值blood_typeCHAR:=0;blood_typeCHARDEFAULT0;vNOTNULL,必须有缺省值emp_countNUMBER(3)
4、NOTNULL:=0;变量的定义与使用%TYPEv使用其它变量或列的数据类型,但不继承NOTNULL属性vcreditNUMBER(7,2);vdebitcredit%TYPE;经常用于表中字段的数据类型vmy_dnamesalers.sname%TYPE;优点:不需要知道精确类型;在表定义发生变化时,不用修改程序变量的定义与使用%ROWTYPEvDECLAREvemp_recemp%ROWTYPE;vCURSORc1ISSELECTdeptno,dname,locFROMdept;vdept_recc1%ROWTYPE;变量的定义与使用v赋值与计算、比较使用:=作为赋值运算符其他计算、比较方
5、法类似于普通语言v作用域外层定义的变量可以在子块中使用可以在不同块中定义同名变量子块可以通过外层的块名来引用外层变量内嵌SQLv可以直接在PL/SQL中使用DQL和DML,但不能使用DDL和DCLv在SQL语句中使用变量的值可以出现表达式的地方都可以使用变量直接写变量名,不需要额外的语法要素v容易和字段混淆v在MSSQL中,使用:作为前缀通常出现在where子句、select子句内嵌SQLv将查询结果赋值给一个变量SELECTINTOFROM子句其他子句v要求SELECT语句必须返回必须返回1行结果行结果,若返回多行或0行会在运行时报错必须在逻辑上保证返回一条记录,例如使用主键、聚合函数。与子
6、查询不同,返回0行也是错误如何进行错误处理,见后面章节5.3 控制流语句v条件语句简单条件语句多重条件语句v循环语句LOOP循环WHILE循环FOR循环v跳转语句EXITGOTOv空语句控制流语句-条件vIFTHENENDIF;vvIFTHENELSEENDIF;vIFTHENELSIFTHENELSIFTHENELSEENDIF;控制流语句-循环vLOOP.LOOP.EXITWHEN ENDLOOP;.ENDLOOP;控制流语句-循环vWHILELOOPENDLOOP;vFORIN.REVERSELOOPENDLOOP;控制流语句-其他v定义标号v跳转GOTO;v空语句NULL;v返回RET
7、URN;5.4 过程与函数v过程与函数的作用v维护过程与函数v外部过程与内部过程v调用与参数传递过程与函数-维护v过程(procedure)CREATEORREPLACEPROCEDURE()AS|IS;v:=IN|OUT|INOUTDEFAULTv:无长度和精度ALTERPROCEDURECOMPILE;DROPPROCEDURE;过程与函数-维护v函数(function)CREATEORREPLACEFUNCTION()RETURNAS|IS;ALTERFUNCTIONCOMPILE;DROPFUNCTION;创建过程v计算某顾客在给定时间前一年的总购买金额CREATE PROCEDURE
8、 p_1 (v_cid IN CHAR,v_sum OUT NUMBER,v_date IN DATE DEFAULT SYSDATE)AS BEGIN SELECT SUM(dollars)INTO v_sum FROM orders WHERE cid=v_cid AND buy_date BETWEEN v_date-365 AND v_date;END;vCREATEFUNCTIONf_1(v_cidINCHAR,v_dateINDATE)RETURNNUMBER ASDECLAREv_sumNUMBER;BEGINSELECTSUM(dollars)INTOv_sumFROMorde
9、rsWHEREcid=v_cidANDbuy_dateBETWEENv_date-365ANDv_date;RETURNv_sum;END;创建和函数复杂过程举例CREATE OR REPLACE PROCEDURE INS_SPLIT_WORD(WORD IN VARCHAR2,P_KIND IN NUMBER)ASBEGIN DECLARE CC NUMBER;I NUMBER;J NUMBER;SS VARCHAR2(100);SZ NUMBER;BEGIN DELETE FROM TMP_SPLIT WHERE KIND=P_KIND;IF WORD IS NULL THEN RETU
10、RN;END IF;I:=1;SZ:=LENGTH(WORD);CC:=0;LOOP CC:=CC+1;J:=INSTR(WORD,;,I);IF J=0 THEN J:=SZ+1;END IF;SS:=SUBSTR(WORD,I,J-I);INSERT INTO TMP_SPLIT (SEQ,KIND,SP)VALUES (CC,P_KIND,SS);EXIT WHEN JSZ;I:=J+1;END LOOP;END;END INS_SPLIT_WORD;v内部子过程在过程或函数的DECLARE部分定义,只供该过程或函数调用不能被外部使用声明时不使用关键字CREATE放在DECLARE中的最
11、后部分先声明后使用,可前向声明。不单独存放在数据库中外部过程与内部过程内部过程举例CREATE PROCEDURE p_3 AS BEGIN DECLARE v1 NUMBER;PRODECURE lp_1 AS BEGIN END;PROCEDURE lp_2 AS BEGIN lp_1;END;BEGIN lp_1;lp_2;END;END;SQL*PLUS中,使用EXECUTE命令。在其他PL/SQL程序中,直接写出过程及参数vCREATEPROCEDUREp_2ASBEGINDECLAREv1NUMBER(10);BEGINp_1(C001,v1,SYSDATE);/全局过程p_1EN
12、D;END;执行方法位置表示vcredit_acct(acct,amt);名称表示vcredit_acct(amount=amt,acct_no=acct);vcredit_acct(acct_no=acct,amount=amt);混和表示vcredit_acct(acct,amount=amt);如果默认值在前,后面有非默认值,必须使用名称调用方式。参数传递语法INOUTIN OUT指定指定缺省类型作用作用传递参数传送返回值传送参数和返回值形式参数形式参数如同一个常数未初始化变量已初始化变量不能赋值不能用于表达式、必须赋值应该赋值实际参数参数可以是常量、变量、表达式变量变量传递方式方式值传
13、送引用传送引用传送参数类型包(Package)v由多个过程可以组成包v调试使用的包DBMS_OUTPUT.PUT_LINE();vDBMS_OUTPUT:包名vPUT_LINE:过程名5.5 游标v游标的作用v使用游标v游标FOR循环v游标属性v修改游标中数据游标的作用v用来处理从数据库中查询出来的一组数据的机制。v游标查询返回的数据称为结果集(resultset)。v游标的使用类似文件操作,包括OPEN、FETCH、CLOSE等操作。v游标的类型显式游标隐含游标vPL/SQL为每一个DML语句隐含定义了一个游标包游标使用游标v声明在DECLARE段v打开v循环读取读取当前行的数据到变量中判断
14、是否读到末尾v关闭关闭后才可以重新打开游标声明v声明CURSOR()RETURNIS;:IN:=|DEFAULT参数只能是基本类型,必须是IN类型,可以有缺省值。DECLARE CURSOR c1 IS SELECT sid,sname,salary FROM salers WHERE salary 2000;CURSOR c2 RETURN salers%ROWTYPE IS SELECT*FROM salers WHERE salary 2000;CURSOR c3(v_salary)IS SELECT sid,sname,salary FROM salers WHERE salary v
15、_salary;游标声明使用游标v打开OPEN();可以使用位置表示法和名称表示法。不能打开已经打开的游标。打开游标时带入的参数已经在打开时被固定。v读取数据FETCHINTO|;使用游标v循环读LOOP FETCHc1INTOmy_record;EXITWHENc1%NOTFOUND;ENDLOOP;v关闭CLOSE;举例:计算方差CREATE FUNCTION(f_lid CHAR)ISBEGIN DECLARECURSOR c1(v_lid CHAR)ISSELECT salary FROM salers WHERE lid=v_lid;v_avg NUMBER;v_sum NUMBER
16、 DEFAULT 0;vi NUMBER;BEGINSELECT AVG(salary)INTO v_avg FROM salers WHERE lid=f_lid;OPEN c1(f_lid);LOOP FETCH c1 INTO vi;EXIT WHEN c1%NOTFOUND;v_sum:=v_sum+(vi v_avg)*(vi v_avg);END LOOP;CLOSE c1;RETURN v_sum;END;END;游标FOR循环v自动声明一个和游标返回值相同类型的循环变量、自动打开游标,在每一次循环中读取一行数据,在出错或没有数据时结束循环,关闭游标。同时,当在循环中使用EXIT
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数据库 应用技术 第五 面向 过程 SQL 扩展
限制150内