GRANT (パッケージ特権)
この形式の GRANT ステートメントは、パッケージに対する特権を認可します。
呼び出し
このステートメントは、アプリケーション・プログラムに組み込むことができ、また対話式に呼び出すこともできます。 これは、動的に準備できる実行可能ステートメントです。
権限
このステートメントの権限 ID が保持する特権には、少なくとも以下の 1 つ が含まれていなければなりません。
- ステートメント内で識別された、それぞれのパッケージごとに、
- このステートメントで指定されるすべての特権
- パッケージに対する *OBJMGT システム権限
- パッケージが含まれるスキーマに対する USAGE 特権
- データベース管理者権限
- セキュリティー管理者権限
WITH GRANT OPTION を指定する場合、ステートメントの権限 ID によって保持される特権には、 少なくとも次の 1 つが含まれていなければなりません。
- そのパッケージの所有権
- データベース管理者権限
- セキュリティー管理者権限
構文
.-PRIVILEGES-. >>-GRANT--+-ALL--+------------+-+-------------------------------> | .-,-----------. | | V | | '---+-ALTER---+-+-----' '-EXECUTE-' .-,------------. V | >--ON PACKAGE----package-name-+---------------------------------> .-,---------------------------------. V | >--TO----+-+-------+--authorization-name-+-+--+-------------------+->< | +-USER--+ | '-WITH GRANT OPTION-' | '-GROUP-' | '-PUBLIC------------------------'
説明
- ALL または ALL PRIVILEGES
- 1 つ以上の特権を認可します。認可される特権は、指定されたパッケージに対してステートメントの権限 ID が持っている認可可能な特権のすべてです。
パッケージに対する ALL PRIVILEGES を認可することは、
*ALL システム権限を認可するのと同じではないことに注意する必要があります。
ALL を使用しない場合には、以下にリストしたキーワードの 1 つ以上を使用する必要があります。各キーワードは、そこで説明している特権を認可します。
- ALTER
- COMMENT ステートメントおよび LABEL ステートメントを使用するための特権を認可します。
- EXECUTE
- パッケージのステートメントを実行する特権を認可します。
- ON PACKAGE package-name
- 特権を認可する対象のパッケージを識別します。このパッケージ名 は、現行サーバーに存在してい るパッケージを識別していなければなりません。
- TO
- 特権を認可するユーザーを指定します。
- USER
- authorization-name がユーザー・プロファイルであることを指定します。USER が指定される場合、authorization-name はユーザー・プロファイルでなければなりません。
- GROUP
- authorization-name がグループ・プロファイルであることを指定します。GROUP が指定される場合、authorization-name はグループ・プロファイルでなければなりません。
- authorization-name,…
- 1 つ以上の権限 ID をリストします。
- PUBLIC
- ユーザー (権限 ID) の集合に対して特権を認可します。詳しくは、権限、特権、およびオブジェクト所有権を参照してください。
- WITH GRANT OPTION
- 指定した権限名 が、ON 文節で指定されているパッケージに対する特権を
他のユーザーに認可できるようにします。
WITH GRANT OPTION の指定がない場合は、指定した権限名 は、 ON 文節で指定されているパッケージに対する特権を別のユーザーに認可することができません。 ただし、指定した権限名が、他の何らかの方法で認可できる権限を入手した場合 (例えば、*OBJMGT システム権限の認可) を除きます。
注
対応するシステム権限: GRANT および REVOKE ステートメントは、SQL オブジェクトに対するシステ ム権限の割り当ておよび除去を行います。 次の表は、SQL 特権に対応するシステム権限を示しています。
SQL の特権 | パッケージに対する認可または取り消しに対応するシステム権限 |
---|---|
ALL (ALL の認可または取り消しは、ステートメントの権限 ID が持つ特権の みを認可または取り消します。) | *OBJALTER
*OBJOPR *EXECUTE *OBJMGT (取り消しのみ) |
ALTER | *OBJALTER |
EXECUTE | *EXECUTE
*OBJOPR |
WITH GRANT OPTION | *OBJMGT |
パッケージへの権限を検査する際の対応するシステム権限: 次の表は、 パッケージへの権限を検査する際の、SQL 特権に対応するシステム権限を示しています。 左側の欄は、SQL 特権をリストしています。 右側の欄は、同等のシステム権限をリストしています。
SQL の特権 | パッケージへの特権を検査する際の、対応するシステム権限 |
---|---|
ALTER | *OBJALTER |
EXECUTE | *EXECUTE および *OBJOPR
|
代替構文: 以下のキーワードは、旧リリースとの互換性を維持するためにサポートされている同義語です。 これらのキーワードは標準キーワードではないので、原則として使用しないようにしてください。
- EXECUTE の同義語としてキーワード RUN を使用することができます。
- PACKAGE の同義語として、キーワード PROGRAM を使用することができます。
例
パッケージ PKGA に関する EXECUTE 特権を PUBLIC に対して認可します。
GRANT EXECUTE
ON PACKAGE PKGA
TO PUBLIC