ALTER POLICY (original) (raw)
ALTER POLICY — change the definition of a row-level security policy
Synopsis
ALTER POLICY name
ON tablename
RENAME TO newname
ALTER POLICY name
ON tablename
[ TO { rolename
| PUBLIC | CURRENT_ROLE | CURRENT_USER | SESSION_USER } [, ...] ]
[ USING ( usingexpression
) ]
[ WITH CHECK ( checkexpression
) ]
Description
ALTER POLICY
changes the definition of an existing row-level security policy. Note that ALTER POLICY
only allows the set of roles to which the policy applies and the USING
and WITH CHECK
expressions to be modified. To change other properties of a policy, such as the command to which it applies or whether it is permissive or restrictive, the policy must be dropped and recreated.
To use ALTER POLICY
, you must own the table that the policy applies to.
In the second form of ALTER POLICY
, the role list, usingexpression
, and checkexpression
are replaced independently if specified. When one of those clauses is omitted, the corresponding part of the policy is unchanged.
Parameters
name
The name of an existing policy to alter.
tablename
The name (optionally schema-qualified) of the table that the policy is on.
newname
The new name for the policy.
rolename
The role(s) to which the policy applies. Multiple roles can be specified at one time. To apply the policy to all roles, use PUBLIC
.
usingexpression
The USING
expression for the policy. See CREATE POLICY for details.
checkexpression
The WITH CHECK
expression for the policy. See CREATE POLICY for details.
Compatibility
ALTER POLICY
is a PostgreSQL extension.