通过shell脚本查看package的信息(r2笔记86天)

有时候想查看一个package的信息,但是对于package的名字不是很确定,比如只知道一个大概,知道一些关键字,这个时候通过图形工具是查找不到package的信息的,而且对于package的信息,我只关心package里面有哪些存储过程,哪些函数等,看看简单的参数情况就可以了,类似sqlplus的desc的形式。 shell脚本的实现如下, 以下的脚本是查看是否有对应的package信息。 PROC_OWNER=`sqlplus -silent $DB_CONN_STR@$SH_DB_SID <<END set pagesize 50 feedback off verify off heading on echo off col owner format a20 col object_name format a30 col subobject_name format a10 set linesize 150 break on object_name select object_name,owner,subobject_name,object_type,object_id, created,last_ddl_time,status from dba_objects where object_type like 'PACKAGE%' and object_name like upper('$2%') and owner=upper('$1') order by object_name / exit; END` if [ -z "$PROC_OWNER" ]; then echo "no object exists, please check again" exit 0 else echo '*******************************************' echo " $PROC_OWNER "

PACK_LIST=` sqlplus -s $DB_CONN_STR@$SH_DB_SID <<END col name format a30 col text format a100 set linesize 200 set pages 50 break on name select name,text from dba_source where owner like UPPER('$1') and name like upper('$2%') and type='PACKAGE' and (text like '%PROCEDURE %' or text like '%FUNCTION %' ) order by name,line; exit; END` echo " $PACK_LIST " echo '*******************************************' fi exit

运行脚本的情况如下所示。

[ora11g@rac1 dbm_lite]$ ksh findpack.sh sys  dbms_metadata
*******************************************
 
OBJECT_NAME                     OWNER                SUBOBJECT_ OBJECT_TYPE          OBJECT_ID CREATED    LAST_DDL_ STATUS
------------------------------ --------------------  ---------- ------------------- ---------- --------- ---------  -------
DBMS_METADATA                  SYS                              PACKAGE BODY             11981 23-JAN-14 23-JAN-14  VALID
                               SYS                              PACKAGE                   8399 23-JAN-14 23-JAN-14  VALID
DBMS_METADATA_BUILD            SYS                              PACKAGE                   8401 23-JAN-14 23-JAN-14  VALID
                               SYS                             PACKAGE  BODY             11984 23-JAN-14 23-JAN-14  VALID
DBMS_METADATA_DIFF             SYS                             PACKAGE  BODY             11986 23-JAN-14 23-JAN-14  VALID
                               SYS                              PACKAGE                   8405 23-JAN-14 23-JAN-14  VALID
DBMS_METADATA_DPBUILD          SYS                             PACKAGE  BODY             11985 23-JAN-14 23-JAN-14  VALID
                               SYS                              PACKAGE                   8403 23-JAN-14 23-JAN-14  VALID
DBMS_METADATA_INT              SYS                             PACKAGE  BODY             11982 23-JAN-14 23-JAN-14  VALID
                               SYS                              PACKAGE                   9666 23-JAN-14 23-JAN-14  VALID
DBMS_METADATA_UTIL             SYS                              PACKAGE                   9681 23-JAN-14 23-JAN-14  VALID
                               SYS                             PACKAGE  BODY             11983 23-JAN-14 23-JAN-14 VALID    
 
NAME                           TEXT
------------------------------  ----------------------------------------------------------------------------------------------------
DBMS_METADATA                     FUNCTION open (
                                 PROCEDURE set_filter  (
                                 PROCEDURE set_filter  (
                                 PROCEDURE set_filter  (
                                 PROCEDURE set_count  (
                                 PROCEDURE set_xmlformat  (
                                 FUNCTION get_query  (
 

如果想知道更多的package的信息,可以使用如下的脚本。

PROC_OWNER=`sqlplus -silent $DB_CONN_STR@$SH_DB_SID <<END  
set pagesize 40 feedback off verify off heading on echo off
col owner  format a20
col object_name format a30
col subobject_name format a10
set  linesize 150
break on object_name
select  object_name,owner,subobject_name,object_type,object_id,  created,last_ddl_time,status from dba_objects where object_type like 'PACKAGE%'  and object_name=upper('$2') and owner=upper('$1')
ORDER BY  OBJECT_ID
/
exit;
END`
if [ -z "$PROC_OWNER" ]; then
 echo "no object exists, please check  again"
 exit 0
else
 echo  '*******************************************'
 echo " $PROC_OWNER     "
 echo '*******************************************'
fi

sqlplus -silent $DB_CONN_STR@$SH_DB_SID <<EOF
prompt .
set long 99999
set pages 0
select text
from  dba_source 
where type in ('PACKAGE BODY','PACKAGE') and name=upper('$2') and  owner=upper('$1')
order by type, line;
EOF
exit

脚本运行情况如下:

[ora11g@rac1 dbm_lite]$ ksh showpack.sh sys  DBMS_METADATA_UTIL|less
*******************************************
 
OBJECT_NAME                     OWNER                SUBOBJECT_ OBJECT_TYPE          OBJECT_ID CREATED    LAST_DDL_ STATUS
------------------------------ --------------------  ---------- ------------------- ---------- --------- ---------  -------
DBMS_METADATA_UTIL             SYS                              PACKAGE                   9681 23-JAN-14 23-JAN-14  VALID
                               SYS                             PACKAGE  BODY             11983 23-JAN-14 23-JAN-14 VALID     
*******************************************
.
PACKAGE  dbms_metadata_util AUTHID DEFINER  AS
------------------------------------------------------------
--  Overview
-- This pkg implements utility functions of the  mdAPI.
---------------------------------------------------------------------
--  SECURITY
-- This package is owned by SYS. It runs with definers, not invokers  rights
-- because it needs to access dictionary tables.
-------------
-- EXCEPTIONS
--
  invalid_argval EXCEPTION;
     PRAGMA EXCEPTION_INIT(invalid_argval, -31600);
    invalid_argval_num NUMBER  := -31600;
-- "Invalid input value %s for parameter %s in function %s"
--  *Cause:  A NULL or invalid value was supplied for the parameter.
-- *Action:  Correct the input value and try the call again.
    invalid_operation EXCEPTION;
    PRAGMA  EXCEPTION_INIT(invalid_operation, -31601);
    invalid_operation_num NUMBER  := -31601;
-- "Function %s cannot be called now that fetch has begun"
--  *Cause:  The function was called after the first call to FETCH_xxx.
--  *Action: Correct the program. 

原文发布于微信公众号 - 杨建荣的学习笔记(jianrong-notes)

原文发表时间:2014-09-05

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏大内老A

WCF版的PetShop之二:模块中的层次划分[提供源代码下载]

上一篇文章主要讨论的是PetShop的模块划分,在这一篇文章中我们来讨论在一个模块中如何进行层次划分。模块划分应该是基于功能的,一个模块可以看成是服务于某项功能...

258100
来自专栏乐沙弥的世界

Heap size 80869K exceeds notification threshold (51200K)

      前阵子的alert日志获得了所需堆尺寸的大小超出指定阙值的提示,即Heap size 80869K exceeds notification thr...

10730
来自专栏陈满iOS

iOS·宏封装线程锁小技巧

9210
来自专栏数据和云

12c RMAN新特性之Recover Table

周玉其 云和恩墨南区技术顾问,曾在电信、物流等行业从事多年数据库开发、管理工作。

9020
来自专栏乐沙弥的世界

收缩表段(shrink space)

--==================== -- 收缩表段(shrink space) --==================== 一、表的增长方式  ...

28510
来自专栏菩提树下的杨过

oracle:如何用sql生成日历

BI分析中,经常需要将事实表与时间维度表关联起来,按年/月/日来逐层展示,常用的做法是创建一张日历表,结构类似如下: create table T_BAS_CA...

40460
来自专栏乐沙弥的世界

Oracle Scheduler Chain 的用法

      Oracle CHAIN,也就是链,是将一串需要完成的作业连在一起,根据每一个步骤完成的不同结果来确定下面的哪一个动作需要被完成。实际上也就是if ...

9110
来自专栏杨建荣的学习笔记

巧用shell脚本分析数据库用户(r2第4天)

在数据库维护中,可能对于一个陌生的schema,需要了解它的一些情况,可以使用如下的脚本来很快得到一个报告,里面包含了详尽的信息。 用户占用的空间,权限,角色和...

35070
来自专栏向治洪

android AlarmManager讲解

Android系统闹钟定时功能框架,总体来说就是用数据库存储定时数据,有一个状态管理器来统一管理这些定时状态的触发和更新。在Andriod系统中实现定时功能,...

74350
来自专栏数据和云

追本溯源:Oracle 只读表空间的探索实践

作者简介 ? 胡中豪 云和恩墨西区交付工程师,多年一线 DBA 经验,曾服务于运营商、电网、政府行业、银行等行业客户;擅长数据库故障处理、性能优化、实施升级 本...

29530

扫码关注云+社区

领取腾讯云代金券