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

时间:2022-05-04
本文章向大家介绍通过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.