前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >通过shell脚本查看package的信息(r2笔记86天)

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

作者头像
jeanron100
发布2018-03-14 17:01:58
7200
发布2018-03-14 17:01:58
举报

有时候想查看一个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

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

代码语言:javascript
复制
[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的信息,可以使用如下的脚本。

代码语言:javascript
复制
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

脚本运行情况如下:

代码语言:javascript
复制

[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. 
本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2014-09-05,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 杨建荣的学习笔记 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档