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

数据库 Oracle
以下是一篇有关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更改的默认端口号剖析
责任编辑:佚名
相关推荐

2009-04-16 09:08:21

Oracle开发经验

2011-03-31 09:55:59

Oracle数据库开发技术

2010-08-10 15:02:18

Oracle认证数据库

2009-02-03 08:58:13

SQL*Net配置网络应用

2009-10-13 09:43:43

Oracle数据库备份

2009-04-13 10:06:58

Oracle安全管理

2022-08-02 08:01:09

开发插件Chrome前端技术

2011-07-25 16:21:22

Sencha touc

2020-08-31 07:00:00

数据库数据库同步

2009-05-19 10:10:01

Oracle时间加减时间操作

2009-07-15 16:23:54

Java JDBC

2010-04-02 18:22:33

Sun Oracle

2009-06-24 16:30:21

JSF组件模型

2012-03-26 09:27:40

谷歌安卓开发谷歌安卓

2011-06-09 18:24:36

QT Wince

2023-05-15 18:44:07

前端开发

2009-04-20 14:29:41

Oracle连接创建连接

2021-11-26 22:07:57

数据库管理Mongodb

2022-01-16 22:16:59

数据库Sentry开发者

2011-04-18 11:00:34

使用音频BlackBerry
点赞
收藏

51CTO技术栈公众号