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