透過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指令碼 – 檢視網路介面資訊指令碼
- 通過shell指令碼檢測MySQL服務資訊指令碼MySql
- Laravel 透過遷移指令碼建立MySQL檢視Laravel指令碼MySql
- 【資訊採集】IBM AIX系統硬體資訊檢視命令(shell指令碼)IBMAI指令碼
- Bash 指令碼實現每次登入到 Shell 時可以檢視 Linux 系統資訊指令碼Linux
- 透過shell指令碼監控日誌切換頻率指令碼
- shell指令碼企業巡檢指令碼
- Shell 系統資訊監控指令碼指令碼
- Linux透過什麼命令可以檢視報文的詳細資訊?Linux
- linux透過shell指令碼實現ssh互動式自動化Linux指令碼
- 通過shell指令碼批量操作mysql資料庫指令碼MySql資料庫
- 傳送kafka訊息的shell指令碼Kafka指令碼
- Laravel 通過遷移指令碼建立MySQL檢視Laravel指令碼MySql
- 透過 Prometheus 編寫 TiDB 巡檢指令碼(指令碼已開源,內附連結)PrometheusTiDB指令碼
- [ Shell ] 通過 Shell 指令碼匯出 CDL 網表指令碼
- 指令碼 - 透過 mac 反查 IP指令碼Mac
- Hibernate批處理如何透過“datasource-proxy”檢視詳細資訊?
- [ Shell ] 通過 Shell 指令碼匯出 GDSII/OASIS 檔案指令碼
- 如何使用 Shell 指令碼來檢視多個伺服器的埠是否開啟?指令碼伺服器
- shell指令碼指令碼
- 通過shell指令碼防止埠掃描指令碼
- 檢測不同伺服器上程式碼差別的shell的指令碼伺服器指令碼
- 通過shell指令碼 批量新增使用者指令碼
- linux常用的shell指令碼Linux指令碼
- 常用shell指令碼指令碼
- shell指令碼案例指令碼
- Linux Shell指令碼Linux指令碼
- MySQL資料庫備份的shell指令碼MySql資料庫指令碼
- 透過Python指令碼理解系統程式Python指令碼
- 使用shell 指令碼備份資料指令碼
- php百萬資料透過指令碼檔案寫入csvPHP指令碼
- shell指令碼(6)-shell陣列指令碼陣列
- 一個快速檢視trace的小指令碼指令碼
- 程式碼上線的shell指令碼指令碼
- 案例:通過shell指令碼實現mysql資料備份與清理指令碼MySql
- 尚矽谷大資料視訊_Shell視訊教程大資料
- Liunx備份mysql資料庫的shell指令碼MySql資料庫指令碼
- linux shell指令碼中 =~ 的作用Linux指令碼
- shell指令碼總結指令碼