- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第8章 存储过程和触发器 存储过程和触发器 8.1 存储过程 8.2 创建存储过程 8.3 创建带参数的存储过程 8.4 管理存储过程 8.5 触发器 8.6 创建触发器 8.7 管理触发器 8.8 本章小结 8.1 存储过程 在Oracle中,可以在数据库中定义的子程序,这种程序块称为存储过程(Procedure)。它的定义存储在在数据字典中,可以在不同用户和应用程序之间共享,并可实现程序的优化和重用。 8.2 创建存储过程 用户存储过程只能定义在当前数据库中,可以通过CREATE PROCEDURE命令或OEM创建存储过程,创建存储过程用户要求具有相应的权限。 8.2.1 创建和执行存储过程 8.2.2 使用OEM创建存储过程 8.2.1 创建和执行存储过程 创建存储过程的基本语法如下: CREATE [OR REPLACE] PROCEDURE [schema.]procedure_name /*定义过程名*/ [(parameter parameter_mode data_type,…n)]/*定义参数类型及属性*/ IS | AS BEGIN sql_statement END procedure_name; 8.2.1 创建和执行存储过程 【例8.1】创建存储过程“print_current_time”,用于打印当前系统的时间。代码如下: CREATE or replace PROCEDURE print_current_time AS curtime VARCHAR2(20); BEGIN SELECT TO_CHAR(SYSDATE,yyyy/mm/dd hh24:mi:ss) INTO curtime FROM DUAL; DBMS_OUTPUT.PUT_LINE(当前时间是:||curtime); END print_current_time; 8.2.1 创建和执行存储过程 创建过程之后即可执行过程。用户既可以从匿名PL/SQL程序块中直接调用,也可以在SQL*Plus中使用EXECUTE()函数来执行。基本语法如下: EXEC[UTE] procedure_name[(parameter, …n)]; 8.2.1 创建和执行存储过程 【例8.2】使用EXEC函数执行存储过程“print_current_time”,如图8.1所示。 EXEC print_current_time 【例8.3】使用匿名PL/SQL程序块执行过程“print_current_time”,如图8.2所示。 8.3 创建带参数的存储过程 Oracle中还可以创建带参数的存储过程,扩展存储过程的功能。存储过程的参数有3种类型:分别为IN、OUT和IN OUT类型。 IN:表示参数是输入给过程的。 OUT:表示参数在过程中将被赋值,可以传给过程体的外部。 IN OUT:表示该类型的参数既可以向过程体传值,也可以在过程体中赋值。 8.3 创建带参数的存储过程 【例8.5】在“Student”数据库中,创建存储过程“st_kcpjf”,并通过一个输出参数,用于返回某课程的平均分数。如图8.5所示。 CREATE OR REPLACE PROCEDURE kc_avg(in_kc IN 课程表.课程名%type, out_score OUT NUMBER) AS BEGIN SELECT AVG(成绩) INTO out_score FROM 成绩表 WHERE 课程号=(SELECT 课程号 FROM 课程表 WHERE 课程名=in_kc); END kc_avg; 8.3 创建带参数的存储过程 【例8.6】执行存储过程“kc_avg”,输出“SQL Server 2005”课程的平均分数。代码如下: SET SERVEROUTPUT ON DECLARE out_score NUMBER; BEGIN kc_avg(SQL Server 2005,out_score); DBMS_OUTPUT.PUT_LINE(课程平均成绩为:||out_score); END; 8.3 创建带参数的存储过程 【例8.7】创建存储过程“c_num”,用来统计“学生表”中不同性别的人数。代码如下: CREATE OR REPLACE PROCEDURE c_num (in_sex IN CHAR,out_num OUT NUMBER) AS BEGIN IF in_sex =男 THEN SELECT COUNT(性别) INTO out_num FROM 学生表 WHERE 性别=男; ELSE SELECT COUNT(性别) INTO ou
您可能关注的文档
最近下载
- 人教版七年级数学上册第五章一元一次方程.pptx VIP
- 超星学习通网课《从爱因斯坦到霍金的宇宙》尔雅答案2025题目及答案.docx
- 证监会行业分类指引 2012版 (2).xls VIP
- 通信中级整理-终端与业务.pdf VIP
- 【初中数学】第五章一元一次方程单元测试+2024-2025学年人教版数学七年级上册.docx VIP
- 快乐日记(三上日记范文).docx VIP
- 4.1 《喜看稻菽千重浪》课件(共46张PPT)统编版高中语文必修上册.pptx VIP
- 群众安全满意度培训课件.pptx VIP
- 石材厂15万吨年砂石料加工项目突发环境事件应急预案2024年第一版.docx VIP
- 道德与法治人教版二年级上册教案.doc VIP
原创力文档


文档评论(0)