PL/SQLパッケージ、プロシージャ、またはファンクションが使用されているかどうかを確認するにはどうすればよいですか。 PL/SQLパッケージ、プロシージャ、またはファンクションの使用状況に関する統計を含むOracle表またはビューがありますか。PL/SQLパッケージ、プロシージャ、またはファンクションが使用されているかどうかをどのように確認できますか?
答えて
デフォルトではありません。ただし、監査のOracleデータベースの機能を使用できます。 Ask Tomは、プロシージャコールの監査に関する長いスレッドです!
オブジェクトに依存性があるかどうかは、DBA_DEPENDENCIES表を問い合せることによって確認できます。
SELECT OWNER,
NAME,
TYPE
FROM SYS.DBA_DEPENDENCIES
WHERE REFERENCED_OWNER = '<your object owner>'
AND REFERENCED_NAME = '<your object name>'
AND REFERENCED_TYPE IN ('PACKAGE', 'PROCEDURE', 'FUNCTION');
このクエリでは、Oracleインスタンス自体の内部で記憶されたコード内の任意の依存関係を返します。
オブジェクトがインスタンス外で呼び出されたかどうかはわかりません。
これはどのように質問に答えるかわかりませんが、プロシージャは依存関係がなく、次のレイヤから直接呼び出され、別のプロシージャはいくつかの依存関係を持つ可能性がありますが、呼び出されることはありませんそれで、決して "使われていない"。あなたはあなたの答えを精緻化して、それがどのように問題に対処しているかを示すことができます。私はあなたがサイトの初心者であるので、これをdownvotingしていない、BTW、ようこそ! – jachguate
元の質問には、別の層の発信者を探しているかどうかは言及されていませんでした。 Oracleインスタンス自体が、インスタンス外のどのレイヤーが特定の関数を呼び出すのかを知ることは不可能です。私の回答は、単にOracleインスタンスに格納されているコードの依存関係を表示することでした。 – JordanBean
Oracle 11(R2?)を使用している場合、PL/Scope
にチャンスを与えます。
文書番号PL/Scopeは、プログラム単位のコンパイル時にPL/SQLソースコード内の識別子に関するデータを収集し、静的データ辞書ビューで使用できるようにするコンパイラ主導のツールです。収集されたデータには、識別子の種類、用途(宣言、定義、参照、呼び出し、割り当て)、およびソースコード内の各用途の場所に関する情報が含まれます。
PL /スコープの時間を過ごしたブラウジングを最小限にし、ソースコードを理解することにより、PL/SQL 開発者の生産性を向上させる強力かつ効果的なPL /スコープのソースコードブラウザの開発を可能にします。
あなたはhttp://download.oracle.com/docs/cd/E11882_01/appdev.112/e17125/adfns_plscope.htm#g1010526
PL/ScopeはOPの状況には役立ちません。*潜在的に*使用されていない関数やプロシージャが実際に*使用されている頻度を知りたがっています。 –
でそれについての詳細を見つけることができますまた、あなたは何をしようとしてために有用PL/SQL計装パッケージILOを見つけるかもしれません。
SELECT * FROM all_source
where UPPER(TEXT) like UPPER('%procedure_name%')
または
SELECT * FROM all_source
where UPPER(TEXT) like UPPER('%package.function_name%')
あなたは自己参照を無視する必要がありますが、それは見つけることは簡単なはず:
また、USER/ALL_SOURCEを照会してみてください。
また、user/all_viewsから "view"ソースを確認する必要があります。しかし、ビューソースのクエリに関する他の質問を参照してください。
あなたはまた、パッケージまたはトップレベル関数/プロシージャが
select * from all_dependencies
where referenced_name like '%PACKAGE_NAME%';
NBで使用されているかどうかを確認することができます:あなたは、特に、その後差し出がましい機能を探している場合に必要
としてALL_/DBA_にUSER_切り替えます別のオプションは、警告を使用してコードをコンパイラにあるあなたがヒキガエルのようなエディタを使用することができますオンにしてからPLW-06002を探してLPW-06006
exec DBMS_WARNING.add_warning_setting_cat('ALL','ENABLE','SESSION')
create or replace function x return number
as
procedure y is begin null; end;
begin
return 0;
return 1;
end;
show errors
Errors for FUNCTION X:
LINE/COL ERROR
-------- -----------------------------------------------------------------
1/1 PLW-05018: unit X omitted optional AUTHID clause; default value DEFINER used
3/1 PLW-06006: uncalled procedure "Y" is removed.
6/1 PLW-06002: Unreachable code
。プロシージャーが依存するオブジェクトと、プロシージャーを参照するオブジェクトの両方を直接リストします。
- 1. LinkedListが既に注文されているかどうかはどのように確認できますか?
- 2. ビューがレイアウトされているかどうかをどのように確認できますか?
- 3. QMutexがロックされているかどうかをどのように確認できますか?
- 4. DotNet Core 1.1を使用しているかどうかはどのように確認できますか?
- 5. sybaseプロシージャが隠されているかどうかを確認するクエリ
- 6. ポートが使用されているかどうかを確認しますか?
- 7. プッシュ通知がiOSで配信されたかどうかはどのように確認できますか?
- 8. GTK +どのラジオボタンが選択されているかはどのようにして確認できますか?
- 9. WebページでRESTまたはSOAP Webサービスが使用されているかどうかを確認するにはどうすればよいですか?
- 10. コンピュータが再起動されたかどうかをどのように確認できますか?
- 11. Sitecore:ImageMagickが使用されているかどうかを確認するには?
- 12. ダーティチェックが使用されているかどうかを確認するには?
- 13. プロシージャがパッケージに存在するかどうかを確認する方法はありますか?
- 14. iPhoneがドッキングされているかどうか確認できますか?
- 15. require_onceは "ファイルが既に含まれているかどうか"をどのように確認しますか?
- 16. エラーが返されたかどうかを確認するにはどうすればよいですか?
- 17. リンクが訪問されたかどうかを確認するにはどうすればよいですか?
- 18. どのようにvimがコンパイルされたオプションを確認できますか?
- 19. フォームが送信されたかどうかはどのように確認されますか?
- 20. シンボルパッケージが特定のNugetパッケージ用に公開されているかどうかを確認するにはどうすればよいですか?
- 21. Bluetoothヘッドセットデバイスで使用されているa2dpのバージョンはどのようにして確認できますか?
- 22. Seleniumスクリプトがログインできたかどうかを確認するにはどうすればよいですか?
- 23. インポートされたライブラリがPythonスクリプトで '使用されている'かどうかを確認するにはどうすればよいですか?
- 24. Mercurialを使用して、どのような変更がまだプッシュされていないかをどのように確認できますか?
- 25. PyMongoを使用してユーザーがデータベースで認証されているかどうかを確認するにはどうすればよいですか?
- 26. OSにプログラム/パッケージがインストールされているかどうかを確認する方法はありますか?
- 27. PYTHONSTARTUP変数が定義されているかどうかをどのように確認しますか?
- 28. テーブルがSQLサーバーで使用されているかどうかを確認することができます
- 29. モデルのデータが正確にどのように接続されているか確認できますか?
- 30. インテントフィルタがアプリケーションで使用されているかどうかを確認する
これを削除して、ユーザーからの電話があったかどうかを確認します。 :-) –
ほとんど使用されないパッケージ/ proc /関数が存在する可能性があるため、 "usage"を定義してください。削除する必要はありません。 –