[转帖]一个最简单的oracle存储过程"proc_helloworld" _MySQL, Oracle及数据库讨论区_Weblogic技术|Tuxedo技术|中间件技术|Oracle论坛|JAVA论坛|Linux/Unix技术|hadoop论坛_联动北方技术论坛  
网站首页 | 关于我们 | 服务中心 | 经验交流 | 公司荣誉 | 成功案例 | 合作伙伴 | 联系我们 |
联动北方-国内领先的云技术服务提供商
»  游客             当前位置:  论坛首页 »  自由讨论区 »  MySQL, Oracle及数据库讨论区 »
总帖数
1
每页帖数
101/1页1
返回列表
0
发起投票  发起投票 发新帖子
查看: 1995 | 回复: 0   主题: [转帖]一个最简单的oracle存储过程"proc_helloworld"         下一篇 
napolenAx
注册用户
等级:少校
经验:802
发帖:118
精华:1
注册:2011-8-30
状态:离线
发送短消息息给napolenAx 加好友    发送短消息息给napolenAx 发消息
发表于: IP:您无权察看 2015-1-9 10:56:26 | [全部帖] [楼主帖] 楼主

本文通过一个最简单的oracle存储过程"proc_helloworld"的实验,展现一下存储过程的开发和维护过程,适合超超超级初学小牛(like me)。

1.编写。编写一个最最简单的存储过程,给它起个名字叫做proc_helloworld

CREATE OR REPLACE PROCEDURE proc_helloworld
IS
BEGIN
DBMS_OUTPUT.put_line ('Hello World!');
END;
/


2.创建。在sqlplus命令行界面创建该存储过程

sys@ora10g> conn sec/sec
Connected.
sec@ora10g> CREATE OR REPLACE PROCEDURE proc_helloworld
2  IS
3  BEGIN
4     DBMS_OUTPUT.put_line ('Hello World!');
5  END;
6  /
Procedure created.


3.运行。两种方法运行存储过程
1).需要在屏幕上显示出"DBMS_OUTPUT.put_line"的输出字符串,需要做一个小小的设置

sec@ora10g> show serveroutput
serveroutput OFF
sec@ora10g> set serveroutput on
sec@ora10g> show serveroutput
serveroutput ON SIZE 10000 FORMAT WORD_WRAPPED


2).在sqlplus命令行界面使用"EXECUTE"命令(简写做"EXEC")执行

sec@ora10g> exec proc_helloworld
Hello World!
PL/SQL procedure successfully completed.


3).在一个无名PL/SQL块内运行存储过程

BEGIN
proc_helloworld;
END;
/
sec@ora10g> BEGIN
2     proc_helloworld;
3  END;
4  /
Hello World!
PL/SQL procedure successfully completed.


4.修改。修改一个存储过程只需要将修改好的存储过程在sqlplus界面先重新执行一下即可,因为在创建过程中使用的是"CREATE OR REPLACE PROCEDURE",也就是说如果没有就创建,如果已经存在了这个存储过程,就替换它

CREATE OR REPLACE PROCEDURE proc_helloworld
IS
BEGIN
DBMS_OUTPUT.put_line ('Hello World! '||chr(10)||'I am a Happy DBA Secooler!');
END;
/


或者

CREATE OR REPLACE PROCEDURE proc_helloworld
IS
BEGIN
DBMS_OUTPUT.put_line ('Hello World!
I am a Happy DBA Secooler!');
END;
/
sec@ora10g> CREATE OR REPLACE PROCEDURE proc_helloworld
2  IS
3  BEGIN
4     DBMS_OUTPUT.put_line ('Hello World! '||chr(10)||'I am a Happy DBA Secooler!');
5  END;
6  /
Procedure created.


看一下执行效果:

sec@ora10g> exec proc_helloworld;
Hello World!
I am a Happy DBA Secooler!
PL/SQL procedure successfully completed.


5.调试。对于非常复杂的存储过程的调试是真正体现个人魅力和能力的地方,往往需要很多的经验,这个急不得,只能慢慢来 Take it easy.
在sqlplus下调试存储过程时,如果出现错误,时刻使用"show errors"命令查看哪里出错了,例如:

sec@ora10g> CREATE OR REPLACE PROCEDURE proc_helloworld
2  IS
3  BEGIN
4     DBMS_OUTPUT.put_line ('Hello World!');
5  END
6  /
Warning: Procedure created with compilation errors.
sec@ora10g> show errors
Errors for PROCEDURE PROC_HELLOWORLD:
LINE/COL ERROR
-------- -----------------------------------------------------------------
5/3      PLS-00103: Encountered the symbol "end-of-file" when expecting
one of the following:
; <an identifier> <a double-quoted delimited-identifier>
delete exists prior <a single-quoted SQL string>
The symbol ";" was substituted for "end-of-file" to continue.


通过提示,问题出现在END后面没有分号结束符号,修改后问题得到处理

sec@ora10g> CREATE OR REPLACE PROCEDURE proc_helloworld
2  IS
3  BEGIN
4     DBMS_OUTPUT.put_line ('Hello World!');
5  END;
6  /
Procedure created.


6.删除。使用drop语句删除存储过程

sec@ora10g> select object_name,object_type,status from user_objects where OBJECT_TYPE='PROCEDURE';
OBJECT_NAME                    OBJECT_TYPE         STATUS
------------------------------ ------------------- -------
PROC_HELLOWORLD                PROCEDURE           VALID
sec@ora10g> DROP PROCEDURE proc_helloworld;
Procedure dropped.
sec@ora10g> select object_name,object_type,status from user_objects where OBJECT_TYPE='PROCEDURE';
no rows selected


7.获取。在维护存储过程的过程中往往需要快速的获取存储过程的SQL创建语句,我经常使用的有如下两种方法
1).使用DBMS_METADATA包获得

sec@ora10g> SELECT DBMS_METADATA.get_ddl ('PROCEDURE', 'PROC_HELLOWORLD') from dual;
DBMS_METADATA.GET_DDL('PROCEDURE','PROC_HELLOWORLD')
--------------------------------------------------------------------------------
CREATE OR REPLACE PROCEDURE "SEC"."PROC_HELLOWORLD"
IS
BEGIN
DBMS_OUTPUT.put_line ('Hello World!');
END;


2).使用"USER_SOURCE"视图获得,本人推荐使用这种方法查看,格式标准,内容也全面

sec@ora10g> SELECT text FROM user_source WHERE NAME = 'PROC_HELLOWORLD';
TEXT
------------------------------------------------------------------------------------------------------------------------------
PROCEDURE proc_helloworld
IS
BEGIN
DBMS_OUTPUT.put_line ('Hello World!');
END;


8.小结
上面的实验,我通过编写、创建、运行、修改、调试、删除和获取七个内容描述了一个存储过程的开发和维护过程。
试验,实验还有实践,技术工作者永远不变的途径!

Goodluck Friends!
-- The End --


--转自 北京联动北方科技有限公司




赞(0)    操作        顶端 
总帖数
1
每页帖数
101/1页1
返回列表
发新帖子
请输入验证码: 点击刷新验证码
您需要登录后才可以回帖 登录 | 注册
技术讨论