龙盟编程博客 | 无障碍搜索 | 云盘搜索神器
快速搜索
主页 > 数据库类 > Oracle 技术 >

修改Oracle存储过程所需代码

时间:2011-04-12 23:18来源:未知 作者:admin 点击:
分享到:
我们都知道当我们在修改一个 Oracle 存储过程时,我们的写一个输出的相关的字符串,即Hello World!,在Oracle存储过程中,要用Notepad打开skeleton.sql 文件,. 用DBMS_OUTPUT.PUT_LINE 过程调用去替

我们都知道当我们在修改一个Oracle存储过程时,我们的写一个输出的相关的字符串,即“Hello World!”,在Oracle存储过程中,要用Notepad打开skeleton.sql 文件,. 用DBMS_OUTPUT.PUT_LINE 过程调用去替换NULL语句,如下所示:

Java代码

  1. CREATE OR REPLACE PROCEDURE skeleton   
  2. IS   
  3. BEGIN   
  4. DBMS_OUTPUT.PUT_LINE('Hello World!');   
  5. END;   
  6. CREATE OR REPLACE PROCEDURE skeleton  
  7. IS  
  8. BEGIN  
  9. DBMS_OUTPUT.PUT_LINE('Hello World!');  
  10. END;  

保存到文件skeleton.sql.

从SQL*Plus命令行, 打开文件skeleton.sql .

Java代码

  1. SQL> @skeleton   
  2. SQL>   
  3. CREATE OR REPLACE PROCEDURE skeleton   
  4. IS   
  5. BEGIN   
  6. DBMS_OUTPUT.PUT_LINE('Hello World!');   
  7. * END;   
  8. SQL> @skeleton  
  9. SQL> 
  10. CREATE OR REPLACE PROCEDURE skeleton  
  11. IS  
  12. BEGIN  
  13. DBMS_OUTPUT.PUT_LINE('Hello World!');  
  14. * END;  
  15. SQL> /   

SQL*Plus 通知你Oracle存储过程成功创建并输出提示信息:Procedure created.

SQL>

用EXECUTE 命令运行你的存储过程:

SQL> EXECUTE skeleton;

SQL*Plus显示存储过程运行成功:

  1. PL/SQL procedure successfully completed.  

我们想要的输出字符串 "Hello World!"没有出来,在显示一个DBMS_OUTPUT.PUT_LINE 结果前需要运行一个SET命令,在SQL*Plus 命令行提示符,键入:

  1. SQL> SET SERVEROUTPUT ON  

再次执行你的Oracle存储过程:

  1. SQL> EXECUTE skeleton;  

现在结果输出了:Hello World!

  1. PL/SQL procedure successfully completed.  

调试一个存储过程

当调试一个存储过程时,遵循一样的步骤,修改SQL文件,创建存储过程,执行存储过程,根据编译器反馈的出错信息进行修改,这一步是非常繁琐的,需要依靠经验。

在实际的商用存储过程的开发调试过程中,由于涉及很多表、类型、光标、循环、条件等复杂的逻辑,和PL/SQL语句的灵活运用,编译时会产生很多错误提示信息,程序员在根据这些错误信息定位,进行修正,再编译最后得到正确的结构;
 

修改一个Oracle存储过程

让我们写一个输出字符串“Hello World!”的存储过程,用Notepad打开你的skeleton.sql 文件,. 用DBMS_OUTPUT.PUT_LINE 过程调用去替换NULL语句,如下所示:

Java代码

  1. CREATE OR REPLACE PROCEDURE skeleton   
  2. IS   
  3. BEGIN   
  4. DBMS_OUTPUT.PUT_LINE('Hello World!');   
  5. END;   
  6. CREATE OR REPLACE PROCEDURE skeleton  
  7. IS  
  8. BEGIN  
  9. DBMS_OUTPUT.PUT_LINE('Hello World!');  
  10. END;  

保存到文件skeleton.sql.

从SQL*Plus命令行, 打开文件skeleton.sql .

Java代码

  1. SQL> @skeleton   
  2. SQL>   
  3. CREATE OR REPLACE PROCEDURE skeleton   
  4. IS   
  5. BEGIN   
  6. DBMS_OUTPUT.PUT_LINE('Hello World!');   
  7. * END;   
  8. SQL> @skeleton  
  9. SQL> 
  10. CREATE OR REPLACE PROCEDURE skeleton  
  11. IS  
  12. BEGIN  
  13. DBMS_OUTPUT.PUT_LINE('Hello World!');  
  14. * END;  
  15. SQL> /   

SQL*Plus 通知你存储过程成功创建并输出提示信息:Procedure created.

SQL>

用EXECUTE 命令运行你的存储过程:

  1. SQL> EXECUTE skeleton;  

SQL*Plus显示Oracle存储过程运行成功:

  1. PL/SQL procedure successfully completed.  

我们想要的输出字符串 "Hello World!"没有出来,在显示一个DBMS_OUTPUT.PUT_LINE 结果前需要运行一个SET命令,在SQL*Plus 命令行提示符,键入:

  1. SQL> SET SERVEROUTPUT ON  

再次执行你的存储过程:

  1. SQL> EXECUTE skeleton;  

现在结果输出了:

  1. Hello World!   
  2. PL/SQL procedure successfully completed.   

上述的相关内容就是对Oracle存储过程的描述,希望会给你带来一些帮助在此方面。

精彩图集

赞助商链接