Manage users and roles
This page documents the preview version (v2.21). Preview includes features under active development and is for development and testing only. For production, use the stable version (v2024.1). To learn more, see Versioning.
Roles in YSQL can represent individual users or a group of users. Users are a role that has login permissions.
You manage roles and users using the CREATE ROLE, GRANT, REVOKE, and DROP ROLE statements.
YSQL and case sensitivity
Like SQL, YSQL is case-insensitive by default. When specifying an identifier, such as the name of a table or role, YSQL automatically converts the identifier to lowercase. For example,CREATE ROLE Alice
creates the role "alice". To use a case-sensitive name for an identifier, enclose the name in quotes. For example, to create the role "Alice", use CREATE ROLE "Alice"
.
Create roles
You can create roles with the CREATE ROLE statement.
For example, to create a role engineering
for an engineering team in an organization, do the following:
yugabyte=# CREATE ROLE engineering;
Roles that have LOGIN
privileges are users. For example, create a user john
as follows:
yugabyte=# CREATE ROLE john LOGIN PASSWORD 'PasswdForJohn';
Read about how to create users in YugabyteDB in the Authentication section.
Grant roles
You can grant a role to another role (which can be a user), or revoke a role that has already been granted. Executing the GRANT and the REVOKE operations requires the AUTHORIZE
privilege on the role being granted or revoked.
For example, you can grant the engineering
role you created above to the user john
as follows:
yugabyte=# GRANT engineering TO john;
Read more about granting privileges.
Create a hierarchy of roles
In YSQL, you can create a hierarchy of roles. The privileges of any role in the hierarchy flows downward.
For example, you can create a developer
role that inherits all the privileges from the engineering
role.
First, create the developer
role.
yugabyte=# CREATE ROLE developer;
Next, GRANT
the engineering
role to the developer
role.
yugabyte=# GRANT engineering TO developer;
List roles
You can list all the roles by running the following statement:
yugabyte=# SELECT rolname, rolcanlogin, rolsuper, memberof FROM pg_roles;
You should see the following output:
rolname | rolcanlogin | rolsuper | memberof
-------------+-------------+----------+-----------------
john | t | f | {engineering}
developer | f | f | {engineering}
engineering | f | f | {}
yugabyte | t | t | {}
(4 rows)
In the table, note the following:
- The
yugabyte
role is the built-in superuser. - The role
john
can log in, and hence is a user. Note thatjohn
is not a superuser. - The roles
engineering
anddeveloper
cannot log in. - Both
john
anddeveloper
inherit the roleengineering
.
Revoke roles
Revoke roles using the REVOKE statement.
For example, you can revoke the engineering
role from the user john
as follows:
yugabyte=# REVOKE engineering FROM john;
Listing all the roles now shows that john
no longer inherits from the engineering
role:
yugabyte=# SELECT rolname, rolcanlogin, rolsuperuser, memberof FROM pg_roles;
rolname | rolcanlogin | rolsuper | memberof
-------------+-------------+----------+-----------------
john | t | f | {}
developer | f | f | {engineering}
engineering | f | f | {}
yugabyte | t | t | {}
(4 rows)
Drop roles
Drop roles using the DROP ROLE statement.
For example, you can drop the developer
role with the following statement:
yugabyte=# DROP ROLE developer;
The developer
role is no longer present when listing all the roles:
yugabyte=# SELECT rolname, rolcanlogin, rolsuper, memberof FROM pg_roles;
rolname | rolcanlogin | rolsuper | memberof
-------------+-------------+----------+-----------
john | t | f | {}
engineering | f | f | {}
yugabyte | t | t | {}
(3 rows)