説明
V4.3x系では、このビューはV4.3.3バージョンから導入されました。V4.2.x系では、このビューはV4.2.4バージョンから導入されました。
機能の概要
ビューrole_column_grantsは、現在のセッションでユーザーに付与された有効なロールの列権限情報、およびこれらのロールが他のロールに付与した列権限情報を表示します。
フィールドの説明
| フィールド名 | タイプ | NULL値を許容するか | 説明 |
|---|---|---|---|
| GRANTOR | null | NO | このロールに権限を付与するアカウントのユーザー名部分。OceanBaseデータベースでは、この値は常にNULLです。 |
| GRANTOR_HOST | null | NO | このロールに権限を付与するアカウントのホスト部分。OceanBaseデータベースでは、この値は常にNULLです。 |
| GRANTEE | varchar(32) | NO | このロールに対応するアカウントのユーザー名部分。 |
| GRANTEE_HOST | varchar(255) | NO | このロールに対応するアカウントのホスト名部分。 |
| TABLE_CATALOG | varchar(3) | NO | このロールに付与されたディレクトリの名前。この値は常にdefです。 |
| TABLE_SCHEMA | varchar(64) | NO | このロールに付与されたテーブルが属するデータベース名。 |
| TABLE_NAME | varchar(64) | NO | このロールに付与されたテーブルの名前。 |
| COLUMN_NAME | varchar(64) | NO | このロールに付与されたテーブルの列名。 |
| PRIVILEGE_TYPE | varchar(31) | NO | 付与される権限。この値は、指定されたテーブルの列レベルで付与される任意の権限であり、各行は特定の列のすべての権限を示します。 |
| IS_GRANTABLE | varchar(3) | NO | このロールの権限を他のユーザーに付与できるかどうか。 |
クエリ例
ロールとテーブルを作成します。
obclient [test]> CREATE ROLE employee;obclient [test]> CREATE TABLE tbl1(c1 int, c2 int, c3 int);ロールに列レベルの権限を付与します。
obclient [test]> GRANT INSERT (c1, c2), SELECT (c1) ON test.tbl1 TO employee;ユーザーにロールを付与します。
obclient [test]> GRANT employee TO user1;ユーザー
user1を使用してデータベースに接続します。現在のセッションで
employeeロールを有効化します。obclient [test]> SET ROLE employee;現在のセッションでユーザーに付与された有効なロールの列権限情報を確認します。
obclient [test]> USE information_schema;obclient [test]> SELECT * FROM information_schema.role_column_grants;クエリ結果は次のとおりです:
+---------+--------------+----------+--------------+---------------+--------------+------------+-------------+----------------+--------------+ | GRANTOR | GRANTOR_HOST | GRANTEE | GRANTEE_HOST | TABLE_CATALOG | TABLE_SCHEMA | TABLE_NAME | COLUMN_NAME | PRIVILEGE_TYPE | IS_GRANTABLE | +---------+--------------+----------+--------------+---------------+--------------+------------+-------------+----------------+--------------+ | NULL | NULL | employee | % | def | test | tbl1 | c1 | Select,Insert | NO | | NULL | NULL | employee | % | def | test | tbl1 | c2 | Insert | NO | +---------+--------------+----------+--------------+---------------+--------------+------------+-------------+----------------+--------------+ 2 rows in set