ALTER REDACTION POLICY modifies a data redaction policy applied to a specified table.
Only the owner of the table to which the redaction policy is applied has the permission to modify the redaction policy.
1 | ALTER REDACTION POLICY policy_name ON table_name WHEN (new_when_expression); |
1 | ALTER REDACTION POLICY policy_name ON table_name ENABLE | DISABLE; |
1 | ALTER REDACTION POLICY policy_name ON table_name RENAME TO new_policy_name; |
1 2 | ALTER REDACTION POLICY policy_name ON table_name action; |
There are several clauses of action:
1 2 3 | ADD COLUMN column_name WITH function_name ( arguments ) | MODIFY COLUMN column_name WITH function_name ( arguments ) | DROP COLUMN column_name |
Specifies the name of the redaction policy to be modified.
Specifies the name of the table to which the redaction policy is applied.
Specifies the new expression used for the redaction policy to take effect.
Specifies whether to enable or disable the current redaction policy.
Specifies the new name of the redaction policy.
Specifies the name of the table column to which the redaction policy is applied.
To add a column, use a column name that has not been bound to any redaction functions.
To modify a column, use the name of an existing column.
To delete a column, use the name of an existing column.
Specifies the name of a redaction function.
Specifies the list of arguments of the redaction function.
1 | CREATE ROLE test_role PASSWORD '{Password}'; |
1 2 3 | DROP TABLE IF EXISTS emp; CREATE TABLE emp(id int, name varchar(20), salary NUMERIC(10,2)); INSERT INTO emp VALUES(1, 'July', 1230.10), (2, 'David', 999.99); |
1 | CREATE REDACTION POLICY mask_emp ON emp WHEN(current_user = 'test_role') ADD COLUMN salary WITH mask_full(salary); |
Modify the expression for a redaction policy to make it take effect for the specified role (If no user is specified, the redaction policy takes effect for the current user by default.):
1 2 | ALTER REDACTION POLICY mask_emp ON emp WHEN (pg_has_role(current_user, 'redact_role', 'member')); ALTER REDACTION POLICY mask_emp ON emp WHEN (pg_has_role('redact_role', 'member')); |
Modify the expression for the data redaction policy to make it take effect for all users.
1 | ALTER REDACTION POLICY mask_emp ON emp WHEN (1=1); |
Disable the redaction policy.
1 | ALTER REDACTION POLICY mask_emp ON emp DISABLE; |
Enable the redaction policy again.
1 | ALTER REDACTION POLICY mask_emp ON emp ENABLE; |
Change the redaction policy name to mask_emp_new.
1 | ALTER REDACTION POLICY mask_emp ON emp RENAME TO mask_emp_new; |
Add a column with the redaction policy used.
1 | ALTER REDACTION POLICY mask_emp_new ON emp ADD COLUMN name WITH mask_partial(name, '*', 1, length(name)); |
Modify the redaction policy for the name column. Use the MASK_FULL function to redact all data in the name column.
1 | ALTER REDACTION POLICY mask_emp_new ON emp MODIFY COLUMN name WITH mask_full(name); |
Delete an existing column where the redaction policy is used.
1 | ALTER REDACTION POLICY mask_emp_new ON emp DROP COLUMN name; |