- 1、本文档共26页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
ORACLE05PLSQL编程基础
ORACLE 第五讲 PL/SQL编程基础 本章目标 掌握PL/SQL数据类型及变量常量的定义 掌握对象类型的赋值和使用 掌握接收用户输入值及使用 掌握分支结构 掌握循环结构 PL/SQL程序块基本结构 declare 变量,常量,数据对象的声明。 begin 功能语句部分 [exception 异常处理语句部分] end; PL/SQL数据类型 PL/SQL数据类型 int ,整型 number,数字型 varchar2,字符型 date,日期型 boolean,布尔型 PL/SQL变量的定义 创建变量 语法: 变量名 数据类型 举例: stuname varchar2(100); PL/SQL常量的定义 创建常量 语法: 常量名 CONSTANT 数据类型:=值 举例: pi CONSTANT number:=3.14; PL/SQL变量的赋值 变量的赋值 语法: 变量名 数据类型:=值 变量名:=值(之前已定义过变量) select…into 变量名 举例: i int:=5; i int; i:=5; select count(*) into icount from emp; 综合举例:求圆面积 PL/SQL数据对象类型 字段变量-%type 定义:id emp.empno%type; 记录变量-%rowtype 定义:r_emp emp%rowtype; 赋值: select empno into id from emp where ename=‘SMITH’; select * into r_emp from emp where empno=‘7369’; PL/SQL数据对象类型 综合举例:输出编号为7369的部门编号、姓名。 PL/SQL接受用户输入值 语法: 参数名,参数名是弹出的对话框上显示的文字,当有参数输入后则会替换’参数名‘,例如,empno=编号,输入7369之后,则在程序运行时即为empno=7369 注意:如果接受的参数不是数字型或整型,那么要用‘ ’,引起来。 PL/SQL接受用户输入值 用法: e_empno emp.empno%type:=empno; select ename,sal into r_emp.ename, r_emp.sal from emp where empno=empno; 综合举例: 输入半径求得圆的面积。 输入员工编号获得该员工的编号和职位 输入员工姓名获得该员工的编号和职位 PL/SQL分支结构 IF…THEN END IF; IF…THEN … ELSE … END IF; PL/SQL分支结构 IF…THEN ELSIF…THEN ELSIF…THEN ELSE END IF; PL/SQL分支结构 CASE selector WHEN…THEN… WHEN…THEN… ELSE… END CASE; PL/SQL分支结构 接收一个部门号,根据不同的部门号,为其下面的员工增加相应的sal。 如果员工编号为7369,则输出员工姓名、薪水。(如果不是则输出“不是我所找的人!”) PL/SQL循环结构 LOOP loop 计数器 exit when 退出条件; …(循环体) end loop; WHILE while 循环条件 loop …(循环体) end loop; PL/SQL循环结构 FOR for 循环条件 loop …(循环体) end loop; 求1到100的和。 PL/SQL异常—预定义异常 NO_DATA_FOUND 在表中不存在请求的行时出现。此外,当程序引用已经删除的元素时,也会引发此异常 TOO_MANY_ROWS 在执行SELECT INTO语句后返回多行时出现 ZERO_DIVIDE 除数为零 PL/SQL异常—预定义异常 ACCESS_INTO_NULL 在未初始化对象时出现 CASE_NOT_FOUND 在CASE语句中的选项与用户输入的数据不匹配时出现 COLLECTION_IS_NULL 在给尚未初始化的表或数组赋值时出现 PL/SQL异常—预定义异常 CURSOR_ALREADY_OPEN 在用户试图重新打开已经打开的游标时出现。在重新打开游标前必须先将其关闭 INVALID_CURSOR 在执行非法游标运算(如打开一个尚未打开的游标)时出现 PL/SQL异常—预定义异常 VALUE_ERROR 在产生大小限制错误时出现。例如,变量中的列值超出变量的大小 PL/SQL异常—预定义异常 用法: declare begin exception when 预定义异
文档评论(0)