説明
このステートメントは、機密データ保護ルールを作成するために使用されます。
権限要件
CREATE SENSITIVE RULE ステートメントを実行するには、現在のユーザーが CREATE SENSITIVE RULE 権限を持っている必要があります。OceanBaseデータベースの権限の詳細については、MySQLモードの権限分類を参照してください。
構文
CREATE SENSITIVE RULE <rule_name>
ON <sensitive_field_list>
USING ENCRYPTION [ = <encryption_method>];
パラメータ説明
具体的なパラメータ説明は以下のとおりです:
パラメータ |
データ型 |
デフォルト値 |
説明 |
|---|---|---|---|
| rule_name | 文字列 | 暗号化ルール名。テナント内で一意である必要があります。 | |
| sensitive_field_list | 文字列 | 暗号化する列を指定します。形式は db.table(col1, col2), db2.table2(col3, col4), ... です。つまり、各センシティブ項目はテーブル上の1つまたは複数の列を指し、各列はカンマで区切られます。複数のセンシティブ項目はカンマで区切られ、暗号化ルールで保護する列を指定します。1つのルールでは、複数のユーザー、複数のテーブル上の複数の列を指定できます。パラメータの説明:
|
|
| encryption_method | 文字列 | USING ENCRYPTION はパラメータを指定しなくてもかまいません。デフォルトの暗号化アルゴリズムを使用することを意味します。デフォルトは aes-256 で、実際には AES-256-ECB 暗号化アルゴリズムを指します。USING ENCRYPTION = DEFAULT と記述しても同じ意味になります。 |
encryption_method の許容される値は以下のとおりです:
値(SQL構文での使用) |
実際に使用される暗号アルゴリズム |
キー長 |
モード |
説明 |
|---|---|---|---|---|
| aes-256 | AES-256-ECB | 256ビット | ECB | デフォルトのアルゴリズム |
| aes-128 | AES-128-ECB | 128ビット | ECB | |
| aes-192 | AES-192-ECB | 192ビット | ECB | |
| aes-128-gcm | AES-128-GCM | 128ビット | GCM | 高いセキュリティレベル、認証付き暗号化(AEAD)を提供 |
| aes-192-gcm | AES-192-GCM | 192ビット | GCM | 高いセキュリティレベル、認証付き暗号化(AEAD)を提供 |
| aes-256-gcm | AES-256-GCM | 256ビット | GCM | 高いセキュリティレベル、認証付き暗号化(AEAD)を提供 |
| sm4-cbc | SM4-CBC | CBC | 高いセキュリティレベル | |
| sm4-GCM | SM4-GCM | GCM | 高いセキュリティレベル、認証付き暗号化(AEAD)を提供 |
機密ルールを作成する際には、以下の点に注意する必要があります:
- ルールは作成後すぐに有効になります。
- ルール名はテナントレベルでグローバルに一意ですが、機密ルールに対してのみグローバルに一意であり、オブジェクトレベルではありません。つまり、
R1という名前のテーブルとR1という名前の機密ルールは同時に存在できますが、R1という名前の機密ルールを2つ同時に存在させることはできません。 - 機密ルールのデータ保護レベルは 列レベル のみであり、テーブルレベルやデータベースレベルはありません。つまり、テーブル全体またはデータベース全体に対するデータ保護ルールの作成は許可されません。テーブル上のすべての列を暗号化する必要がある場合は、すべての列名を明示的に記述する必要があります。
- 1つのルールで1列または複数列の保護を指定できます。データベースやテーブルをまたいだ保護も可能です。
機密ルールを作成する際には、以下の制限に従う必要があります:
- データ保護ルールは、ユーザーテーブル(ビューを含む)の列にのみ適用できます。システムテーブルの列には適用できません。
- 1列は1つのルールによってのみ保護されます。
例
例:
-- 機密ルールr1を作成し、tbl1(a)、tbl2(b, c)、db2.tbl3(e,f)を保護します。
-- デフォルトの暗号化アルゴリズムAES-256-ECBを使用します。
CREATE SENSITIVE RULE r1 ON tbl1(a), tbl2(b, c), db2.tbl3(e,f)
USING ENCRYPTION;
-- 機密ルールr2を作成し、tbl4(x, y)、tbl5(z)を保護します。
-- sm4-cbc暗号化アルゴリズムを使用します。
CREATE SENSITIVE RULE r2 ON tbl4(x, y), tbl5(z)
USING ENCRYPTION = 'sm4-cbc';