OraclePL/SQL语言基础.pptx
- 文档编号:957224
- 上传时间:2022-10-14
- 格式:PPTX
- 页数:35
- 大小:163.02KB
OraclePL/SQL语言基础.pptx
《OraclePL/SQL语言基础.pptx》由会员分享,可在线阅读,更多相关《OraclePL/SQL语言基础.pptx(35页珍藏版)》请在冰豆网上搜索。
数据库操作与管理语言OracleSQL,第03章:
OraclePL/SQL语言基础,本章目标,PL/SQL语言基本结构PL/SQL变量和常量的声明PL/SQL程序的执行部分了解PL/SQL常用函数,PL/SQL简介,PL/SQL(ProceduralLanguage/SQL,过程语言/SQL)它是结合Oracle过程语言和结构化查询语言的一种扩展语言PL/SQL支持多种数据类型,可以使用条件语句和循环语句等控制结构PL/SQL可用于创建存储过程、触发器和程序包,也可以用来处理业务规则、数据库事件或给SQL命令的执行添加程序逻辑,PL/SQL的优点,支持SQL支持面向对象编程(OOP)更好的性能可移植性与SQL集成安全性,PL/SQL语言的基本结构,PL/SQL语言是程序化程序设计语言。
块(Block)是PL/SQL程序中最基本的结构,所有PL/SQL程序都是由块组成。
PL/SQL的块由变量声明、程序代码和异常处理代码3部分组成:
DECLARE标记声明部分声明一些变量、常量、用户定义的数据类型及游标BEGIN标记主程序体部分开始主程序体,在这里可以加入各种合法语句EXCEPTION标记异常处理部分开始异常处理程序,当程序中出现错误时执行这一部分END标记主程序体结束部分,PL/SQL字符集,PL/SQL语言有效字符包括以下三类所有大写和小写英文字母09的阿拉伯数字操作符,包括(、)、+、-、*、/、!
、=、%等PL/SQL标识符标识符的最大长度为30个字符,不区分大小写,但建议在标识符中适当使用大小写,以增加程序的可读性。
PL/SQL的运算符,PL/SQL语言的运算符算术运算符加(+)、减(-)、乘(*)、除(/)、乘方(*)和连接(|)关系运算符=、(或!
=)、=、=、BETWEEN.AND.、IN、LIKE、ISNULL逻辑运算符逻辑与(AND)、逻辑或(OR)、逻辑非(NOT),PL/SQL常量和变量,在PL/SQL程序运行时,需要定义一些变量来存放一些数据。
常量和变量在使用前必须声明,可以使用DECLARE对变量进行声明,语法如下:
DECLARE;.;在DECLARE块中可以同时声明多个常量和变量。
声明普通常量或变量是需要说明以下信息:
常量或变量的名称常量或变量的数据类型,声明常量,声明常量的基本格式如下:
constant:
=;关键字constant表示声明的是常量。
常量一旦定义,在以后的使用中其值不再改变。
一些固定的大小为了防止有人改变,最好定义成常量。
例如Pass_ScoreconstantINTEGER:
=60;,声明变量,声明变量的基本格式如下:
(宽度):
=;变量声明是没有关键字,但要指定数据类型,宽度和初始值可以定义也可以不定义。
例如AddressVARCHAR2(30):
=地址未知;PL/SQL对一个未初始化的变量,将被默认赋值为NULL例如AddressVARCHAR2(30);,案例,例如SETSERVEROUTPUTON;DECLAREPass_ScoreconstantINTEGER:
=60;AddressVARCHAR2(30):
=北京海淀区;BEGINDBMS_OUTPUT.PUT_LINE(Pass_Score);DBMS_OUTPUT.PUT_LINE(Address);END;,使用SETSERVEROUTPUTON命令设置环境变量SERVEROUTPUT为打开状态,从而使PL/SQL程序能够在SQL*Plus中输出结果使用函数DBMS_OUTPUT.PUT_LINE()可以输出参数的值,PL/SQL程序的执行部分,PL/SQL程序的执行部分包括赋值语句流程控制语句SQL语句游标语句,使用赋值语句,可以在声明变量时或处理变量时设置初始值。
也可以在程序的执行部分对变量进行赋值。
SETServerOutPutON;DECLARETrainNameVARCHAR2(30);BEGINTrainName:
=OracleAdministration;Dbms_output.put_line(TrainName);END;运行结果如下图所示,流程控制语句,流程控制语句是所有过程性程序语言的关键PL/SQL的主要控制语句如下:
if.then.else(elsif)判断if正确则执行then,否则执行else(elsif为嵌套判断)case有逻辑的从数值中做出选择loop.exit.end循环控制,用判断语句执行exitloop.exitwhen.end同上,当when为真时执行exitwhile.loop.end当while为真时循环for.in.loop.end已知循环次数的循环,条件语句IF-1,IF语句是根据条件表达式的值决定执行相应的程序段。
语法结构如下:
IFTHEN.ELSIFTHEN.ELSEENDIF;其中ELSIF子句是可选项。
条件语句IF-2,程序中说明一个整型变量Number,使用IF语句判断Number变量是正数、负数或0。
SETServerOutPutON;DECLARENumberINTEGER:
=-10;BeginIFNumber0THENdbms_output.put_line(正数);ELSEdbms_output.put_line(0);ENDIF;End;执行效果如右图所示:
分支语句CASE-1,分支语句是对指定的变量进行判断,从指定的列表中选择满足条件的行,并把该行的值作为CASE语句的结果返回。
CASE语句的语法结构如下:
CASEWHENTHEN值1WHENTHEN值2.WHENTHEN值nELSE值n+1END;,分支语句CASE-2,声明一个整型变量varDAY和一个字符型变量Result。
使用CASE语句判断varDAY是星期几。
如果变量varDAY在17之间,则能够显示相应的星期信息,否则返回提示信息“数据越界”;SETServerOutPutON;DECLAREvarDAYINTEGER:
=3;ResultVARCHAR2(20);BEGINResult:
=CasevarDAYWHEN1THEN星期一WHEN2THEN星期二WHEN3THEN星期三WHEN4THEN星期四WHEN5THEN星期五WHEN6THEN星期六WHEN7THEN星期日ELSE数据越界END;dbms_output.put_line(Result);END;,循环语句LOOP.EXIT.END-1,此语句的功能是重复执行循环体中的程序块,直到执行EXIT语句,则退出循环。
LOOP.EXIT.END语句的语法结构如下LOOPIFTHENEXITENDIFENDLOOP;,循环语句LOOP.EXIT.END-2,计算14累加SETServerOutPutON;DECLAREvarNumINTEGER:
=1;varSumINTEGER:
=0;BEGINLOOPvarSum:
=varSum+varNum;dbms_output.put_line(varNum);IFvarNum=4THENEXIT;ENDIF;dbms_output.put_line(+);varNum:
=varNum+1;ENDLOOP;dbms_output.put_line(=);dbms_output.put_line(varSum);END;,循环语句LOOP.EXITWHEN.END-1,此循环语句的功能是重复执行循环体中的程序块,直到满足EXITWHEN后面的判断语句,则退出循环。
LOOP.EXITWHEN.END语句的语法结构如下:
LOOPEXITWHENENDLOOP;,循环语句LOOP.EXITWHEN.END-2,重新实现14累加SETServerOutPutON;DECLAREvarNumINTEGER:
=1;varSumINTEGER:
=0;BEGINLOOPvarSum:
=varSum+varNum;dbms_output.put_line(varNum);EXITWHENvarNum=4;dbms_output.put_line(+);varNum:
=varNum+1;ENDLOOP;dbms_output.put_line(=);dbms_output.put_line(varSum);END;,循环语句WHILE.LOOP.ENDLOOP-1,此语句的功能是当WHILE后面的语句条件成立时,重复执行循环体中的程序块。
WHILE.LOOP.ENDLOOP语句语法结构如下:
WHILELOOPENDLOOP;,循环语句WHILE.LOOP.ENDLOOP-2,再次实现14累加SETServerOutPutON;DECLAREvarNumINTEGER:
=1;varSumINTEGER:
=0;BEGINWHILEvarNum=4LOOPvarSum:
=varSum+varNum;dbms_output.put_line(varNum);IFvarNum4THENdbms_output.put_line(+);ENDIF;varNum:
=varNum+1;ENDLOOP;dbms_output.put_line(=);dbms_output.put_line(varSum);END;,循环语句FOR.IN.LOOP.ENDLOOP-1,此语句定义一个循环变量,并指定循环变量的初始值和终止值。
每循环一次循环变量自动加1.FOR.IN.LOOP.ENDLOOP语句的语法如下FORIN.LOOPENDLOOP;,循环语句FOR.IN.LOOP.ENDLOOP-2,再次实现14累加SETServerOutPutON;DECLAREvarNumINTEGER:
=1;varSumINTEGER:
=0;BEGINFORvarNumIN1.4LOOPvarSum:
=varSum+varNum;dbms_output.put_line(varNum);IFvarNum4THENdbms_output.put_line(+);ENDIF;ENDLOOP;dbms_output.put_line(=);dbms_output.put_line(varSum);END;,异常处理,PL/SQL程序在运行过程中,可能会出现错误或异常现象例如:
无法建立到Oracle的连接或用0做除数。
好的程序应该对可能发生的异常情况进行处理,异常处理代码在EXCEPTION块中实现可以使用WHEN语句来定义异常。
WHEN语句的使用方法如下:
EXCEPTIONWHENTHENWHENTHEN.WHENOTHERSTHEN,预定义异常种类,案例,向一个NUMBER类型的变量赋值字符串时,导致异常的发生SETServerOutPutON;DECLAREvarNumNUMBER;BEGINvarNum:
=abc;EXCEPTIONWHENVALUE_ERRORTHENdbms_output.put_line(VALUE_ERROR);END;,PL/SQL常用函数,在PL/SQL编程中,会经常使用Oracle数据库提供的函数来完成用户需要的功能。
除了统计函数之外,还有字符型函数、数值型函数、日期型函数等等。
字符型函数,数值型函数,日期型函数,本章总结,PL/SQL语言基本结构变量和常量的声明流程控制语句常用函数,
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- OraclePL SQL 语言 基础