透過shell指令碼檢視package的資訊
有時候想檢視一個package的資訊,但是對於package的名字不是很確定,比如只知道一個大概,知道一些關鍵字,這個時候透過圖形工具是查詢不到package的資訊的,而且對於package的資訊,我只關心package裡面有哪些儲存過程,哪些函式等,看看簡單的引數情況就可以了,類似sqlplus的desc的形式。
shell指令碼的實現如下,
以下的指令碼是檢視是否有對應的package資訊。
PROC_OWNER=`sqlplus -silent <<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 <<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 <<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 <<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.
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/30633755/viewspace-2127766/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 通過shell指令碼檢視package的資訊指令碼Package
- 透過shell指令碼檢視鎖資訊指令碼
- 透過shell指令碼檢視procedure的資訊指令碼
- 通過shell指令碼檢視procedure的資訊指令碼
- 通過shell指令碼檢視鎖資訊指令碼
- 透過shell指令碼得到資料字典的資訊指令碼
- 透過shell指令碼來檢視Undo中資源消耗高的sql指令碼SQL
- Shell指令碼 – 檢視網路介面資訊指令碼
- 透過shell指令碼檢視資料庫表空間使用情況指令碼資料庫
- 透過shell指令碼分析足彩指令碼
- 通過shell指令碼檢測MySQL服務資訊指令碼MySql
- 透過shell指令碼生成資料統計資訊的報表指令碼
- 透過shell定製ash指令碼指令碼
- Laravel 透過遷移指令碼建立MySQL檢視Laravel指令碼MySql
- 透過shell指令碼監控oracle session指令碼OracleSession
- 檢視備份資訊指令碼指令碼
- 通過shell指令碼來檢視Undo中資源消耗高的sql指令碼SQL
- 【資訊採集】IBM AIX系統硬體資訊檢視命令(shell指令碼)IBMAI指令碼
- 檢視鎖定的session資訊指令碼Session指令碼
- 《通過指令碼檢視哪些ip被佔用》shell筆記指令碼筆記
- 通過shell指令碼得到資料字典的資訊指令碼
- 【shell 指令碼】檢視*.gz 檔案的內容指令碼
- 透過shell指令碼生成查詢表資料的sql指令碼SQL
- 檢視錶的統計資訊SQL指令碼SQL指令碼
- 透過shell指令碼定位效能sql和生成報告指令碼SQL
- 透過shell指令碼監控sql執行頻率指令碼SQL
- 透過shell得到資料庫中許可權的指令碼資料庫指令碼
- 透過shell指令碼抓取awr報告中的問題sql指令碼SQL
- 通過shell指令碼檢視資料庫表空間使用情況指令碼資料庫
- 通過shell指令碼得到資料庫的基本資訊(一)指令碼資料庫
- 透過shell指令碼監控日誌切換頻率指令碼
- shell指令碼-透過lftp同步遠端目錄到本地指令碼FTP
- 透過shell指令碼來得到不穩定的執行計劃指令碼
- 分享檢視統計資訊非常好的指令碼指令碼
- 檢視過去的session鎖情況指令碼Session指令碼
- 通過shell指令碼生成資料統計資訊的報表指令碼
- 檢視Oracle基礎配置資訊和效能相關資訊的指令碼Oracle指令碼
- Bash 指令碼實現每次登入到 Shell 時可以檢視 Linux 系統資訊指令碼Linux