1、ORA-00942: table or view does not exist 指的你要操作的表尚未存在,需要先create出来先。

2、ORA-00922: missing or invalid option 指的是有语法错误。遗漏了分号什么的

3、Warning: Procedure created with compilation errors

比如  create or replace procedure p_test_pro1 is     begin       insert into loginuser(username,passwd) values('admin','123');     end                -------这里遗漏了分号     /   Warning: Procedure created with compilation errors   SQL> show error  --显示出具体的错误所在 Errors for PROCEDURE SCOTT.P_TEST_PRO1:   LINE/COL ERROR -------- ---------------------------------------------------------------------------------------------------- 6/0      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.

4、ORA-06576: not a valid function or procedure name     存储过程p_test_pro1尚未创建

call p_test_pro1    ORA-06576: not a valid function or procedure name

5、ORA-06502: PL/SQL: numeric or value error: character to number conversion error ORA-06512: at "SCOTT.P_TEST_PRO1", line 6 ORA-06512: at line 2

create or replace procedure p_test_pro1 IS                v_pass varchar2(20);            begin                select passwd into v_pass from loginuser where rownum=1;                dbms_output.put_line('密码是:'+v_pass);             end;

当调用p_test_pro1的时候报以上错误,把输出语句中的+改为||

在谈存储过程书写中的一些规则时,先看一下执行它的规则,在命令窗口执行存储过程sp_get_product_prompt       set serveroutput on      var ret1 varchar2(200);      var ret2 varchar2(200);      exec sp_get_product_prompt(83,:ret1,:ret2); --或execute      print ret1;      print ret2;            set serveroutput on      declare         ret1 varchar2(200);         ret2 varchar2(200);      begin         sp_get_product_prompt(83,ret1,ret2);         dbms_output.put_line(ret1);         dbms_output.put_line(ret2);      end;

存储过程入参,不论类型,缺省情况下值都为null,入参和出参不能有长度,其中关键字as可以替换成is,存储过程中变量声明在as和begin之间,同时,存储过程中可以再调用其它的存储过程,如果要保证存储过程之间的事务处理不受影响,可以定义为自治事务。      create or replace procedure say_hello(        v_name in varchar2,        v_flag number,        o_ret out number      )      as      begin        if v_name is null and v_flag is null then --v_name和v_flag都等于null            o_ret := 10;        else            o_ret := 100;         end if;      end;

对于入参为null情况下给予缺省值      create or replace procedure say_hello(        i_name in varchar2,        i_flag number,        o_ret out number      )      as        v_name  varchar2(100);      begin        if i_name is null then            v_name := '0';        else           v_name := i_name;        end if;        insert into phone(..,wname..,) values(..,v_name,..);              end; 或直接在insert语句中调用nvl函数赋缺省值      insert into phone(..,wname..,) values(..,nvl(v_name,' '),..); ----如果将' '写成'',则insert进来的v_name值还是为''等价于null值

带一个参数的存储过程    输入参数in,输入参数不能进行:=赋值,但可以将它赋给as后面定义的变量;    输入参数in,可以作为变量进行条件判断;    默认不写就是in;    存储过程没有重载,这个有参的say_hello会替代已经存在的无参say_hello。

create or replace procedure say_hello(v_name in varchar2)      as      begin         --v_name:='a'; --存储过程入参v_name不能做为赋值目标         dbms_output.put_line('hello '||v_name);       end;

存储过程输入参数作为变量进行条件判断      create or replace procedure say_hello(         i_opFlag in number      )      as         v_name varchar2(100);      begin         if i_opFlag = 1 then     v_name :='0';          else     v_name :='haha';         end if;          dbms_output.put_line('hello '||v_name);       end;

利用存储过程中定义的变量对入参的空值处理:      create or replace procedure say_hello(         i_name in varchar2      )      as         v_name varchar2(100);      begin         if i_name is null then     v_name :='0';          else     v_name :=i_name;--将入赋值给定义变量         end if;          dbms_output.put_line('hello '||v_name);       end;

多个参数的存储过程      create or replace procedure say_hello(         v_first_name in varchar2,         v_last_name in varchar2)      as      begin         dbms_output.put_line('hello '||v_first_name||'.'||v_last_name);      end;

out输出参数,用于利用存储过程给一个或多个变量赋值,类似于返回值      create or replace procedure say_hello(         v_name in varchar2,         v_content out varchar2      )      begin         v_content:='hello'||v_name;      end;

调用:      declare         v_con varchar2(200);         v_in varchar2(20):='wang';      begin         say_hello(v_in,v_con);         dbms_output.put_line(v_con);      end;

in out参数,既赋值又取值      create or replace procedure say_hello(v_name in out varchar2)      as      begin         v_name:='hi '||v_name;      end;

调用:      declare         v_inout varchar2(20):='wangsu';      begin         say_hello(v_inout);         dbms_output.put_line(v_inout);      end;

对存储过程入参赋缺省值      create or replace procedure say_hello(         v_name varchar2 default 'susu',         v_content varchar2 default 'hello'      )      as      begin         dbms_output.put_line(v_name||' '||v_content);      end;

调用:(用指明形参名的方式调用更好)      begin         say_hello();      end;      或      begin         say_hello('cheng');      end;      或      begin      say_hello(v_name=>'cheng');     end;

http://regedit-123.iteye.com/blog/1075151

oracle的存储过程语法(转)的更多相关文章

  1. Oracle存储过程语法

    原文链接:http://www.jb51.net/article/31805.htm Oracle存储过程基本语法 存储过程  1 CREATE OR REPLACE PROCEDURE 存储过程名  ...

  2. [转]Oracle 存储过程语法

    转自:http://www.cnblogs.com/chuncn/archive/2009/04/29/1381282.html 存储过程 1  CREATE OR REPLACE PROCEDURE ...

  3. Oracle创建存储过程、执行存储过程基本语法

    >>>>>>>>>>>>>>>>>>>>>>>>> ...

  4. PB中用oracle的存储过程返回记录集做数据源来生成数据窗口,PB会找不到此存储过程及不能正常识别存储过程的参数问题(转)

    (转)在PB中用oracle的存储过程返回记录集做数据源来生成数据窗口 首先oracle的存储过程写法与MSSQL不一样,差别比较大. 如果是返回数据集的存储过程则需要利用oracle的包来定义游标. ...

  5. Oracle基础 存储过程

    一.子程序 子程序是已命名的PL/SQL块,它们存储在数据库中,可以Wie它们指定参数,可以从任何数据库客户端和应用程序中调用它们.子程序包括存储过程和函数. 子程序包括: 1.声明部分:声明部分包括 ...

  6. oracle中存储过程详解

    oracle中存储过程的使用 过程是指用于执行特定操作的PL/SQL块.如果客户应用经常需要执行特定操作,那么可以考虑基于这些操作建立过程.通过使用过程,不仅可以简化客户应用的开发和维护,而且可以提高 ...

  7. 懵懂oracle之存储过程

    作为一个oracle界和厨师界的生手,笔者想给大家分享讨论下存储过程的知识,因为在我接触的通信行业中,存储过程的使用还是占据了一小块的地位. 存储过程是什么?不得不拿下百度词条的解释来:"存 ...

  8. SQLSERVER存储过程语法详解

    CREATE PROC [ EDURE ] procedure_name [ ; number ] [ { @parameter data_type } [ VARYING ] [ = default ...

  9. Oracle常用语句语法汇总

    第一篇  基本操作 --解锁用户   alter user 用户 account unlock; --锁定用户   alter user 用户 account lock; alter user sco ...

随机推荐

  1. Linux下搭建Oracle11g RAC(4)----配置oracle,grid用户SSH对等性

    虽然在安装软件的过程中,oracle会自动配置SSH对等性,建议在安装软件之前手工配置. 配置oracle用户对等性: node1: [root@node1 ~]# su - oracle node1 ...

  2. Java Nio 笔记

    网上的很多关于NIO的资料是不正确的,nio 支持阻塞和非阻塞模式 关于读写状态切换 在读写状态切换的情况下是不能使用regedit 方法注册,而应该使用以下方式进行 selectionKey.int ...

  3. java Date日期去掉时分秒

    SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");String s = sdf.format(new Date() ...

  4. php快速排序

    快速排序是排序中常用的,效率据说还不错,它使用分治算法实现 将一个大的需要排序的序列,分成两个较小的序列!怎么分呢,需要从序列中找出一个元素作为参考元素,通常的做法是拿第一个元素作为参考元素.当一个序 ...

  5. WEB 开发工具分享

    有好用的工具 : 云盘链接地址:

  6. php 半角与全角相关的正则

    半角的全部确认,带小初音的确认法则 ^[ア-ン゙゚ァ-ョッヲー -]+$ <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Frameset// ...

  7. SSO单点登录之数据同步

    完成单点登录,我们便可以通过只登录一个账号,来访问不同系统,然而会遇到以下问题. 1. 通过A站登录的用户访问B站,在B站并没有真实用户,此时如果在B站新建用户,则可能造成用户信息不全,或者数据冲突等 ...

  8. 一封给“X教授”的回信(讨论Socket通信)

    转载:http://www.cnblogs.com/tianzhiliang/archive/2011/03/02/1969187.html 前几天"X教授"发Email与我讨论S ...

  9. Java设计模式--单列设计模式

    设计模式:解决某一类问题行知最有效的方法.java有23种设计模式 单列设计模式: 解决一个类在内存中只存在一个对象 思路:(要保证对象的唯一性) 1.为了避免其它程序建立该对象,先禁止替他类创建改对 ...

  10. 转: angularjs 指令中动态编译的方法(适用于有异步请求的情况) 内嵌指令无效

    angular的坑很多 例子: 在directive的link中有一个$http请求,当请求完成后根据返回的值动态做element.append('......');这个操作, 能显示没问题,可问题是 ...