REASSIGN_OWNED - change the ownership of database objects owned by a database role
Contents
Compatibility
The REASSIGNOWNED command is a PostgreSQL extension.
Description
REASSIGNOWNED instructs the system to change the ownership of database objects owned by any of the
old_roles to new_role.
Name
REASSIGN_OWNED - change the ownership of database objects owned by a database role
Notes
REASSIGNOWNED is often used to prepare for the removal of one or more roles. Because REASSIGNOWNED does
not affect objects within other databases, it is usually necessary to execute this command in each
database that contains objects owned by a role that is to be removed.
REASSIGNOWNED requires membership on both the source role(s) and the target role.
The DROPOWNED command is an alternative that simply drops all the database objects owned by one or more
roles.
The REASSIGNOWNED command does not affect any privileges granted to the old_roles on objects that are
not owned by them. Likewise, it does not affect default privileges created with ALTERDEFAULTPRIVILEGES.
Use DROPOWNED to revoke such privileges.
See Section 21.4 for more discussion.
Parameters
old_role
The name of a role. The ownership of all the objects within the current database, and of all shared
objects (databases, tablespaces), owned by this role will be reassigned to new_role.
new_role
The name of the role that will be made the new owner of the affected objects.
See Also
DROP OWNED (DROP_OWNED(7)), DROP ROLE (DROP_ROLE(7)), ALTER DATABASE (ALTER_DATABASE(7))
PostgreSQL 17.5 2025 REASSIGNOWNED(7)
Synopsis
REASSIGN OWNED BY { old_role | CURRENT_ROLE | CURRENT_USER | SESSION_USER } [, ...]
TO { new_role | CURRENT_ROLE | CURRENT_USER | SESSION_USER }
