---创建一个表

create table TESTTABLE

(

  id1  VARCHAR2(12),

  name VARCHAR2(32)

)

select t.id1,t.name from TESTTABLE t

insert into TESTTABLE (ID1, NAME)

values ('1', 'zhangsan');





insert into TESTTABLE (ID1, NAME)

values ('2', 'lisi');





insert into TESTTABLE (ID1, NAME)

values ('3', 'wangwu');





insert into TESTTABLE (ID1, NAME)

values ('4', 'xiaoliu');





insert into TESTTABLE (ID1, NAME)

values ('5', 'laowu');

---创建存储过程

create or replace procedure test_count

as

v_total number(1);

begin

  select count(*) into v_total from TESTTABLE;

  DBMS_OUTPUT.put_line('总人数:'||v_total);

end;

--准备

--线对scott解锁:alter user scott account unlock; 

--应为存储过程是在scott用户下。还要给scott赋予password

---alter user scott identified by tiger;

---去命令下运行

EXECUTE test_count;

----在ql/spl中的sql中运行

begin

  -- Call the procedure

  test_count;

end;







create or replace procedure TEST_LIST

      AS 

      ---是用游标

        CURSOR test_cursor IS select t.id1,t.name from TESTTABLE t;

      begin

        for Test_record IN test_cursor loop---遍历游标。在打印出来

           DBMS_OUTPUT.put_line(Test_record.id1||Test_record.name);

           END LOOP;

            test_count;--同一时候运行另外一个存储过程(TEST_LIST中包括存储过程test_count)

            end;

      -----运行存储过程TEST_LIST

      begin 

         TEST_LIST;

         END;

       ---存储过程的參数

        ---IN  定义一个输入參数变量,用于传递參数给存储过程   

        --OUT 定义一个输出參数变量。用于从存储过程获取数据   

        ---IN OUT  定义一个输入、输出參数变量,兼有以上两者的功能  

        --这三种參数仅仅能说明类型,不须要说明详细长度 比方 varchar2(12),defaul 能够不写,可是作为一个程序猿不妨写上。

---创建有參数的存储过程

      create or replace procedure test_param(p_id1 in VARCHAR2 default '0')

        as v_name varchar2(32);

        begin

          select t.name into v_name from TESTTABLE t where t.id1=p_id1;

          DBMS_OUTPUT.put_line('name:'||v_name);

         end;

      ----运行存储过程

      begin

         test_param('1');

       end;

       

       default '0'









      ---创建有參数的存储过程

      create or replace procedure test_paramout(v_name OUT VARCHAR2 )

        as  

        begin

          select name into v_name from TESTTABLE where id1='1';

          DBMS_OUTPUT.put_line('name:'||v_name);

         end;

      ----运行存储过程

    DECLARE  

        v_name VARCHAR2(32);   

        BEGIN  

        test_paramout(v_name);

        DBMS_OUTPUT.PUT_LINE('name:'||v_name);   

        END;  

    -------IN OUT

    ---创建存储过程

    create or replace procedure test_paramINOUT(p_phonenumber in out varchar2)

    as  

    begin 

      p_phonenumber:='0571-'||p_phonenumber;

    end;

    

    ----

    DECLARE  

    p_phonenumber VARCHAR2(32);  

    BEGIN  

    p_phonenumber:='26731092';  

    test_paramINOUT(p_phonenumber);  

    DBMS_OUTPUT.PUT_LINE('新的电话号码:'||p_phonenumber);  

    END;  

    -----sql命令下。查询当前用户的存储过程或函数的源码,

    -----能够通过对USER_SOURCE数据字典视图的查询得到。

USER_SOURCE的结构例如以下:

    

    SQL> DESCRIBE USER_SOURCE ;

    Name Type           Nullable Default Comments                                                                                                      

    ---- -------------- -------- ------- ------------------------------------------------------------------------------------------------------------- 

    NAME VARCHAR2(30)   Y                Name of the object                                                                                            

    TYPE VARCHAR2(12)   Y                Type of the object: "TYPE", "TYPE BODY", "PROCEDURE", "FUNCTION",

    "PACKAGE", "PACKAGE BODY" or "JAVA SOURCE" 

    LINE NUMBER         Y                Line number of this line of source                                                                            

    TEXT VARCHAR2(4000) Y                Source text                                                                                                   

    SQL> 

    ---查询出存储过程的定义语句

    select text from user_source WHERE NAME='TEST_COUNT';

    ----查询存储过程test_paramINOUT的參数

    SQL> DESCRIBE test_paramINOUT;

    Parameter     Type     Mode   Default? 

    ------------- -------- ------ -------- 

    P_PHONENUMBER VARCHAR2 IN OUT  

    SQL> 

    ---查看当前的存储过程的状态是否正确,

    ---VALID为正确,INVALID表示存储过程无效或须要又一次编译

    SELECT STATUS FROM USER_OBJECTS WHERE OBJECT_NAME='TEST_COUNT';

    -----假设要检查存储过程或函数的依赖性,能够通过查询数据字典USER_DENPENDENCIES来确定,该表结构例如以下:

    SQL> DESCRIBE USER_DEPENDENCIES;

    Name                 Type          Nullable Default Comments                                                   

    -------------------- ------------- -------- ------- ---------------------------------------------------------- 

    NAME                 VARCHAR2(30)                   Name of the object                                         

    TYPE                 VARCHAR2(17)  Y                Type of the object                                         

    REFERENCED_OWNER     VARCHAR2(30)  Y                Owner of referenced object (remote owner if remote object) 

    REFERENCED_NAME      VARCHAR2(64)  Y                Name of referenced object                                  

    REFERENCED_TYPE      VARCHAR2(17)  Y                Type of referenced object                                  

    REFERENCED_LINK_NAME VARCHAR2(128) Y                Name of dblink if this is a remote object                  

    SCHEMAID             NUMBER        Y                                                                           

    DEPENDENCY_TYPE      VARCHAR2(4)   Y                                                                               

    SQL>  

    ---查询存储过程TEST_COUNT的依赖关系

    SELECT REFERENCED_NAME,REFERENCED_TYPE FROM USER_DEPENDENCIES WHERE NAME='TEST_COUNT';

版权声明:本文博主原创文章。博客,未经同意不得转载。

Oracle存储过程的简单示例的更多相关文章

  1. 创建并在项目中调用SQLSERVER存储过程的简单示例

    使用SQLSERVER存储过程可以很大的提高程序运行速度,简化编程维护难度,现已得到广泛应用.创建存储过程 和数据表一样,在使用之前需要创建存储过程,它的简明语法是: 引用: Create PROC ...

  2. java 调用mysql的存储过程(简单示例)

    首先我在mysql的test数据库里定义了一个student表: create table student4( id   int   primary key, sanme char(5) ); 插入几 ...

  3. MySQL中的存储函数和存储过程的简单示例

    存储函数 定义 CREATE FUNCTION `fn_sum`(`a` int,`b` int) RETURNS int(11) BEGIN RETURN a + b; END 调用 Navicat ...

  4. 转 Java连接Oracle数据库的简单示例

    https://www.cnblogs.com/joyny/p/11176643.html https://community.oracle.com/thread/4096458 import jav ...

  5. oracle 存储过程 示例

      oracle 存储过程 示例 CreationTime--2018年9月4日09点49分 Author:Marydon 1.情景展示 对VIRTUAL_QRCODELOG表的静态二维码,动态二维码 ...

  6. Oracle创建表语句(Create table)语法详解及示例、、 C# 调用Oracle 存储过程返回数据集 实例

    Oracle创建表语句(Create table)语法详解及示例 2010-06-28 13:59:13|  分类: Oracle PL/SQL|字号 订阅 创建表(Create table)语法详解 ...

  7. [转]使用ADO.NET访问Oracle存储过程

    本文转自:http://www.cnblogs.com/datasky/archive/2007/11/07/952141.html 本文讨论了如何使用 ADO.NET 访问 Oracle 存储过程( ...

  8. Oracle存储过程详解(引用)+补充(转) dbms_output包 good

    执行存储过程时,execute和call的区别 EXEC is a sqlplus command that put its argument as an anonymous pl/sql block ...

  9. Oracle——存储过程的使用

    为什么使用存储过程? 存储过程只在创造时进行编译,以后每次执行存储过程都不需再重新编译,而一般SQL语句每执行一次就编译一次,所以使用存储过程可提高数据库执行速度. 存储过程的定义: 存储过程(Sto ...

随机推荐

  1. 认为C/C++很难理解、找工作面试笔试,快看看这本书!

    假设你是C/C++谁刚开始学习,看这本书.因为也许你读其他的书还不如不看.一定要选择一本好书. 假设你正在准备工作,请认真看这本书,由于这本书会教会你工作中必备的知识,相信你即将面临的语法类题目不会超 ...

  2. NSUserDefaults写作和阅读对象定义自己

    需要编写对象必须实现NSCoding protocol Person Class Person.h #import <Foundation/Foundation.h> #import &q ...

  3. IP Camera 和 Web Camera 差分

    一直以来,,没太注意IP camera 和 Web Camera之间的差,这两个摄像头,昨天晚上.闲来无事Google少数,我们发现,还有两者之间的差异. 1) IP Camera IP Camera ...

  4. 通常编译亲测56Y国际象棋源代码,精仿56Y国际象棋完整的源代码下载!

    今天公布亲测通常应编译56Y国际象棋源代码,精仿56Y牌源代码.喜欢的能够拿去研究.论坛资源太多.我们会把好的资源都公布出来,同一时候欢迎很多其它的程序猿增加我们! 增加我们的共同学习交流!     ...

  5. ant利用先进,ant订单具体解释,ant包,ant包装删除编译jar文件

    在日常的项目开发,经常需要我们可以打包测试.特别是,开发环境是windows.实际情况是linux. 这样的话.一个非常大的程序猿将包,其中将包,这些软件包可能非常大,这里是真正的代码会改变的一部分, ...

  6. [LeetCode]Word Ladder 最短距离字符串转换 (Dijkstra)

    要求最短距离.采纳dijkstra查找节点之间的最短路径. 当心:假设是一个枚举字典22是否元素可以,如果转换,暂停. 提高:每串,带您历数它的字符值事件,对于的长度n一个字符串枚举n*26次要. 设 ...

  7. Light OJ 1406 Assassin`s Creed 减少国家DP+支撑点甚至通缩+最小路径覆盖

    标题来源:problem=1406">Light OJ 1406 Assassin`s Creed 意甲冠军:向图 派出最少的人经过全部的城市 而且每一个人不能走别人走过的地方 思路: ...

  8. web.xmlf多ilter在执行顺序

    1.随着url-pattern路配置filter请务必先实施servlet-name路配置filter    2.随着url-partern路配置filter于.,按web.xml于filter-ma ...

  9. ASP.NET MVC 5 入门摘要

    翻译和编辑的第一阶段后,.我们已经发出12片ASP.NET MVC 5入门文章. 他们中的大多数来自翻译ASP.NET MVC 5 官方教程,因为本系列文章言简意赅,篇幅适中,从一个web站点演示样例 ...

  10. 使用 node-inspector 调试 Node.js

    大部分基于 Node.js 的应用都是执行在浏览器中的, 比如强大的调试工具 node-inspector. node-inspector 是一个全然基于 Node.js 的开源在线调试工具,提供了强 ...