oracle查询所有存储过程内容的方法-Oracle

admin2年前 (2024-06-05)基础运维知识255
点击下载TXT

Oracle 查询所有存储过程内容的方法:

直接查询数据字典视图

SELECT
  OBJECT_NAME,
  OBJECT_TYPE,
  OBJECT_DEFINITION
FROM USER_OBJECTS
WHERE
  OBJECT_TYPE IN ('PROCEDURE', 'FUNCTION');
登录后复制

使用 DBMS_METADATA 包

DECLARE
  cursor_pkg DBMS_METADATA.REF_CURSOR;
BEGIN
  DBMS_METADATA.OPEN_REF_CURSOR(cursor_pkg, 'ALL_OBJECTS', 'PROCEDURE');
  LOOP
    FETCH cursor_pkg INTO object_name, object_type, object_definition;
    EXIT WHEN cursor_pkg%NOTFOUND;
    DBMS_OUTPUT.PUT_LINE(object_name || ' ' || object_type);
    DBMS_OUTPUT.PUT_LINE('=' * LENGTH(object_name) || ' ' || '=' * LENGTH(object_type));
    DBMS_OUTPUT.PUT_LINE(object_definition);
    DBMS_OUTPUT.PUT_LINE('');
  END LOOP;
  DBMS_METADATA.CLOSE_REF_CURSOR(cursor_pkg);
END;
登录后复制

使用 DBMS_UTILITY 包

DECLARE
  cursor_src DBMS_UTILITY.CURSOR_TYPE;
  line VARCHAR2(2000);
  type_owner VARCHAR2(30);
  type_name VARCHAR2(30);
BEGIN
  DBMS_UTILITY.SET_SOURCE(cursor_src, 'all_source');
  LOOP
    FETCH cursor_src INTO line;
    EXIT WHEN cursor_src%NOTFOUND;
    IF line LIKE '%CREATE PROCEDURE%' THEN
      DBMS_UTILITY.PARSE_INTO_HIERARCHY(cursor_src, type_owner, type_name);
      DBMS_OUTPUT.PUT_LINE('Owner: ' || type_owner);
      DBMS_OUTPUT.PUT_LINE('Object: ' || type_name);
      DBMS_OUTPUT.PUT_LINE('=' * LENGTH(type_owner) || ' ' || '=' * LENGTH(type_name));
      DBMS_OUTPUT.PUT_LINE(line);
    ELSIF line LIKE '%CREATE FUNCTION%' THEN
      DBMS_UTILITY.PARSE_INTO_HIERARCHY(cursor_src, type_owner, type_name);
      DBMS_OUTPUT.PUT_LINE('Owner: ' || type_owner);
      DBMS_OUTPUT.PUT_LINE('Object: ' || type_name);
      DBMS_OUTPUT.PUT_LINE('=' * LENGTH(type_owner) || ' ' || '=' * LENGTH(type_name));
      DBMS_OUTPUT.PUT_LINE(line);
    END IF;
  END LOOP;
  DBMS_UTILITY.CLOSE_CURSOR(cursor_src);
END;
登录后复制

相关文章

oracle安装失败怎么办-Oracle

Oracle 安装失败怎么办 在安装 Oracle 时遇到失败的问题是常见的。本文将提供一系列步骤帮助您解决安装失败问题。 步骤 1:检查先决条件 确保您的系统满足 Oracle 系统要求。 检查...

sql本地数据库怎么连接-SQL

SQL 本地数据库连接方法 连接到本地 SQL 数据库需要以下步骤: 第一步:选择数据库管理系统 (DBMS) 最常见的 DBMS 是 MySQL、PostgreSQL、SQL Server 和...

oracle中文怎么设置-Oracle

如何设置 Oracle 的中文环境 Oracle 支持多种语言环境,包括中文。要在 Oracle 中启用中文环境,需要进行以下步骤: 1. 设置客户端语言 打开 Oracle SQL 客户端,如...

oracle审计日志怎么查看-Oracle

如何在 Oracle 中查看审计日志 Oracle 审计日志是一种详细的文件,用于记录数据库中发生的事件。它对于监视数据库活动、检测异常情况和遵守监管要求至关重要。 方法: 1. 检查审计设置 首先...

oracle建库失败怎么删除-Oracle

Oracle 建库失败后如何删除? 问题: Oracle 建库失败后,如何删除失败的数据库? 回答: 在 Oracle 中,可以通过以下步骤删除失败的数据库: 1. 连接到目标实例 使用 sys 作...

navicat怎么引入sql文件-navicat

如何在 Navicat 中导入 SQL 文件 Navicat 是一款流行的数据库管理工具,可用于管理各种数据库系统,包括 MySQL、Oracle 和 PostgreSQL。导入 SQL 文件是 N...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。