调用oracle存储过程详解

整理文档很辛苦,赏杯茶钱您下走!

免费阅读已结束,点击下载阅读编辑剩下 ...

阅读已结束,您可以下载文档离线阅读编辑

资源描述

第7讲PL/SQL块的结构和实例PL/SQL块的结构和实例介绍•学习目标•理解oracle的pl/sql概念•掌握pl/sql编程技术(包括编写过程、函数、触发器...)•pl/sql的介绍•pl/sql是什么•pl/sql(procedurallanguage/sql)是oracle在标准的sql语言上的扩展。•pl/sql不仅允许嵌入sql语言,还可以定义变量和常量,允许使用条件语句和•循环语句,允许使用例外处理各种错误,这样使得它的功能变得更加强大。PL/SQL块的结构和实例•学习必要性•1.提高应用程序的运行性能•2.模块化的设计思想【分页的过程,订单的过程,转账的过程。。】•3.减少网络传输量•4.提高安全性(sql会包括表名,有时还可能有密码,传输的时候会泄露。PL/SQL•就不会)•为什么PL/SQL会快呢?•不好的地方:•移植性不好(换数据库就用不了)PL/SQL块的结构和实例•sqlplus开发工具•sqlplus是oracle公司提供的一个工具,这个因为我们在以前介绍过的:•举一个简单的案例:•编写一个存储过程,该过程可以向某表中添加记录。•一个简单的存储过程•CREATEORREPLACEPROCEDUREproc_helloworldISBEGINDBMS_OUTPUT.put_line('HelloWorld!');END;/PL/SQL块的结构和实例•需要在屏幕上显示出DBMS_OUTPUT.put_line的输出字符串,需要做一个小小的设置SQLshowserveroutputserveroutputOFFSQLsetserveroutputonSQLshowserveroutputONSIZE10000FORMATWORD_WRAPPED•1.创建一个简单的表•Sql代码•1.createtablemytest(namevarchar2(30),passwdvarchar2(30));PL/SQL块的结构和实例•2.创建过程•Sql代码•1.createorreplaceproceduresp_pro1is•2.begin--执行部分•3.insertintomytestvalues(‘杨世顺','m1234');•4.end;•5./•replace:表示如果有sp_pro1,就替换•如何查看错误信息:showerror;•如何调用该过程:•1)exec过程名(参数值1,参数值2...);SQL执行•2)call过程名(参数值1,参数值2...);程序调用PL/SQL块的结构和实例•pl/sqlndeveloper开发工具•pl/sqldeveloper是用于开发pl/sql块的集成开发环境(ide),它是一个独立•的产品,而不是oracle的一个附带品。•举一个简单案例:•编写一个存储过程,该过程可以删除某表记录。•Sql代码•1.createorreplaceproceduresp_pro2is•2.begin--执行部分•3.deletefrommytestwherename='杨世顺';•4.end;PL/SQL块的结构和实例•pl/sql基础•pl/sql介绍•开发人员使用pl/sql编写应用模块时,不仅需要掌握sql语句的编写方法,•还要掌握pl/sql语句及语法规则。pl/sql编程可以使用变量和逻辑控制语句,•从而可以编写非常有用的功能模块。比如:分页存储过程模块、订单处理存储过•程模块、转账存储过程模块。而且如果使用pl/sql编程,我们可以轻松地完成•非常复杂的查询要求。•pl/sql可以做什么•简单分类•过程(存储过程)•函数•块(编程)•触发器•包PL/SQL块的结构和实例•编写规范•编写规范n•1.注释•单行注释--•Sql代码•1.select*fromempwhereempno=7788;--取得员工信息•多行注释/*...*/来划分•2.标志符号的命名规范•1).当定义变量时,建议用v_作为前缀v_sal•2).当定义常量时,建议用c_作为前缀c_rate•3).当定义游标时,建议用_cursor作为后缀emp_cursor•4).当定义例外时,建议用e_作为前缀e_errorPL/SQL块的结构和实例•pl/sql块介绍•介绍n•块(block)是pl/sql的基本程序单元,编写pl/sql程序实际上就是编写•pl/sql块,要完成相对简单的应用功能,可能只需要编写一个pl/sql块,但是•如果想要实现复杂的功能,可能需要在一个pl/sql块中嵌套其它的pl/sql块。•块n结构示意图•pl/sql块由三个部分构成:定义部分,执行部分,例外处理部分。•如下所示:•declare•/*定义部分——定义常量、变量、游标、例外、复杂数据类型*/•begin•/*执行部分——要执行的pl/sql语句和sql语句*/•exception•/*例外处理部分——处理运行的各种错误*/•end;•定义部分是从declare开始的,该部分是可选的;•执行部分是从begin开始的,该部分是必须的;•例外处理部分是从exception开始的,该部分是可选的。•可以和java编程结构做一个简单的比较。PL/SQL块的结构和实例•pl/sql块的实例(1)•实例1-只包括执行部分的pl/sql块n•Sql代码•1.setserveroutputon--打开输出选项•2.begin•3.dbms_output.put_line('hello');•4.end;•相关说明:•dbms_output是oracle所提供的包(类似java的开发包),该包包含一些过程,•put_line就是dbms_output包的一个过程。PL/SQL块的结构和实例•pl/sql块的实例(2)•实例2-包含定义部分和执行部分的pl/sql块n•Sql代码•1.declare•2.v_enamevarchar2(5);--定义字符串变量•3.begin•4.selectenameintov_enamefromempwhereempno=&aa;•5.dbms_output.put_line('雇员名:'||v_ename);•6.end;•7./•如果要把薪水也显示出来,那么执行部分就应该这么写:•Sql代码•1.selectename,salintov_ename,v_salfromempwhereempno=&aa;•相关说明:•&表示要接收从控制台输入的变量PL/SQL块的结构和实例•pl/sql块的实例(3)•实例3-包含定义部分,执行部分和例外处理部分•为了避免pl/sql程序的运行错误,提高pl/sql的健壮性,应该对可能的错误•进行处理,这个很有必要。•1.比如在实例2中,如果输入了不存在的雇员号,应当做例外处理。•2.有时出现异常,希望用另外的逻辑处理•我们看看如何完成1的要求。•相关说明:•oracle事先预定义了一些例外,no_data_found就是找不到数据的例外。•Sql代码•1.declare•2.--定义变量•3.v_enamevarchar2(5);•4.v_salnumber(7,2);•5.begin•6.--执行部分•7.selectename,salintov_ename,v_salfromempwhereempno=&aa;•8.--在控制台显示用户名•9.dbms_output.put_line('用户名是:'||v_ename||'工资:'||v_sal);•10.--异常处理•11.exception•12.whenno_data_foundthen•13.dbms_output.put_line('朋友,你的编号输入有误!');•14.end;•15./PL/SQL块的结构和实例•pl/sql分类--过程,函数,包,触发器•过程•过程用于执行特定的操作,当建立过程时,既可以指定输入参数(in),也可以指•定输出参数(out),通过在过程中使用输入参数,可以将数据传递到执行部分;•通过使用输出参数,可以将执行部分的数据传递到应用环境。在sqlplus中可以•使用createprocedure命令来建立过程。PL/SQL块的结构和实例•实例如下:•1.请考虑编写一个过程,可以输入雇员名,新工资,可修改雇员的工资•2.如何调用过程有两种方法;execcall•3.如何在java程序中调用一个存储过程•问题:如何使用过程返回值?•特别说明:•对于过程我们会在以后给大家详细具体的介绍,现在请大家先有一个概念。•createproceduresp_pro3(spNamevarchar2,newSalnumber)is•--不要写成number(3,2),表明类型就可以了,不需要大小。就好像Java写方法•时的参数一样•Sql代码•1.begin•2.--执行部分,根据用户名去修改工资•3.updateempsetsal=newSalwhereename=spName;•4.end;•5./PL/SQL块的结构和实例•java程序中调用一个存储过程•//演示java程序去调用oracle的存储过程案例•5.try{•6.//1.加载驱动•7.Class.forName(oracle.jdbc.driver.OracleDriver);•8.//2.得到连接•9.Connectionct=DriverManager.getConnection(jdbc:o•racle:thin:@127.0.0.1:1521:MYORA1,scott,m123);•11.//3.创建CallableStatement•12.CallableStatementcs=ct.prepareCall({callsp_pr3(?,?)});•13.//4.给?赋值•14.cs.setString(1,SMITH);•15.cs.setInt(2,10);•17.cs.execute();•18.//关闭•19.cs.close();•20.ct.close();•21.}catch(Exceptione){•22.e.printStackTrace();•23.}•24.}•25.}PL/SQL块的结构和实例•1.使用各种if语句•2.使用循环语句•3.使用控制语句——goto和null;•条件分支语句•pl/sql中提供了三种条件分支语句if—then,if–then–else,if–then•–elsif–then•这里我们可以和java语句进行一个比较•简单的条件判断if–thenn•问题:编写一个过程,可以输入一个雇员名,如果该雇员的工资低于2000,就•给该员工工资增加10%。•Sql代码•1.createorreplaceproceduresp_pro6(spNamevarchar2)is•2.--定义•3.v_salemp.sal%type;•4.begin•5.--执行•6.selectsalintov_salfromempwhereename=spName;•7.--判断•8.ifv_sal2000then•9.updateempsetsal=sal+sal*10%whereename=spName;•10.endif;•11.end;•12./PL/SQL块的结构和实例•二重条件分支if–then–else•问题:编写一个过程,可以输入一个雇员名,如果该雇员的补助不是0就在原来•的基础上增加100;如果补助为0就把补助设为200;•Sql代码•1.createorreplaceproceduresp_pro6(spNamevarchar2)is•2.--定义•3.v_commemp.comm%type;•4.begin•5.--执行•6.selectcommintov_commfromempwhereename=spName;•7.--判断•8.ifv_comm0then•9.updateempsetcomm=comm+100whereename=spN

1 / 34
下载文档,编辑使用

©2015-2020 m.777doc.com 三七文档.

备案号:鲁ICP备2024069028号-1 客服联系 QQ:2149211541

×
保存成功