浅谈Oracle数据库新手开发指南

1 在Oracle数据库中进行过程调试
   Oracle 数据库进行过程调试的格式为:

 
 
 
  1. Declare   
  2. Param_int integrate;  
  3. Begin  
  4.     Null;   
  5. --operate the data  
  6.  end  
  7.  

Sql server 的过程调试格式:

在sql server中过程编写过程为直接编写sql语句

比如以上的过程的脚本在Sql service中实现为

 
 
 
  1. Declare @param_int int  
  2. Null;  
  3. --Operate the data;  
  4.  

2 在Oracle数据库编写存储过程

2.1 整个存储过程各个环节语法注意事项
下面首先提供以下基本格式的存储过程语法结构

 
 
 
  1. CREATE OR REPLACE PROCEDURE cc_getmanualquery  
  2. (  
  3. param_inputNum IN number,  
  4. Param_inputString In varchar,  
  5.      Param_OutNum out varchar  
  6. )  
  7. AS  
  8.     Param_temp Number;  
  9. begin  
  10.       --Operate the data   
  11. end ;  
  12.  
  13.    

注意事项:
1)存储过程接口的参数在多个情况下,需要加上,进行间隔
2)存储过程的变量参数,每个变量的定义后面都加上;
3)存储过程的执行体,在结束后加上;符号。

2.2 If条件语句语法
If语句的格式为:

 
 
 
  1. If ()then  
  2. Begin  
  3. End  
  4. Elsif ()then   
  5. Begin  
  6. End  
  7.    End if  
  8.  

If 语句和Sql Server 格式不一样

在 Sql Server 中的If语句的格式为

 
 
 
  1. If()  
  2. Begin  
  3.  --Operate the data  
  4.  End  
  5. Else ()  
  6.    Begin  
  7.     --Operate The data  
  8. End  
  9.  

2.3返回数据集合的方式

l_cursor out DSPackage.DataSet

定义游标格式的变量,同时在存储过程中,对游标进行设定
在Sql Server 中数据集合返回格式为直接在存储过程的操作区中最后一个select语句,查询的数据结果,这种方式在Oracle数据库中会出现异常。

2.4变量定义 和赋值的方式
在Oracle中变量定义格式
变量名称 varchar
赋值的方式
变量名称:=变量值。
Sql Server 中为

 
 
 
  1. Declare @param int;  
  2. Set @param=1;  
  3.  

2.5使用Select into 的方式进行数据赋值方式时,在没有数据填充的情况下,异常情况

注意在 Oracle数据库中Select 返回结果中没有数据集的情况下,就会发生异常,需要进行异常处理。

在Sql server中 变量为Null.

2.6 oracle数据库中的异常处理

 
 
 
  1. EXCEPTION  
  2.       WHEN OTHERS  
  3.       THEN  
  4.          --返回值赋值  
  5.          raise_application_error (-20000,  
  6.                                   '任务队列入日志库错误' || SQLERRM  
  7.                                  );  
  8.          GOTO proc_end;  
  9.          <<proc_end>> 
  10.          NULL;  
  11.  

2.7 变更影响行号数值的获取

 
 
 
  1. if sql%rowcount = 0 then   
  2.                 begin  
  3.                     open l_cursor for select* from CC_MANUAL where id is null;--表的名字     
  4.                     i_o_state := -9;  
  5.                     v_o_msg   :'更新协查事件表问题标识失败';                               
  6.                     --raise exp;  
  7.                 end;  
  8.              end if;  

 以上sql%rowcount = 0  部分为 判断更新影响的行数是否为0

【编辑推荐】

  1. Oracle性能诊断不能不知的秘籍
  2. 使用dtu远程连接Oracel 9i数据库的方法
  3. Windows2000服务器下安装Oracle9i与10g
  4. Oracle多表查询优化的代码示例
  5. Oracle更改的默认端口号剖析
THE END