The CREATE ROLE statement creates SQL roles, which are groups containing any number of roles and users as members. You can assign privileges to roles, and all members of the role (regardless of whether if they are direct or indirect members) will inherit the role's privileges.
You can use the keywords ROLE and USER interchangeably. CREATE USER is equivalent to CREATE ROLE, with one exception: CREATE ROLE sets the NOLOGIN role option, which prevents the new role from being used to log in to the database. You can use CREATE ROLE and specify the LOGIN role option to achieve the same result as CREATE USER.
The CREATE ROLE statement performs a schema change. For more information about how online schema changes work in CockroachDB, see Online Schema Changes.
Considerations
- After creating a role, you must grant it privileges to databases and tables.
- All privileges of a role are inherited by all of its members.
- Users and roles can be members of roles.
- Role options of a role are not inherited by any of its members.
- There is no limit to the number of members in a role.
- Membership loops are not allowed (direct: A is a member of B is a member of Aor indirect:A is a member of B is a member of C ... is a member of A).
Required privileges
Unless a role is a member of the admin role, additional privileges are required to manage other roles.
- To create other roles, a role must have the CREATEROLErole option.
- To add the LOGINcapability for other roles so that they can log in as users, a role must also have theCREATELOGINrole option.
- To be able to grant or revoke membership to a role for additional roles, a member of the role must be set as a role admin for that role.
Synopsis
Parameters
| Parameter | Description | 
|---|---|
| name | The name of the role to create. | 
| WITH role_option | Apply a role option to a role. | 
Role names
- Are case-insensitive.
- Must start with either a letter or underscore.
- Must contain only letters, numbers, periods, or underscores.
- Must be between 1 and 63 characters.
- Cannot be none.
- Cannot start with pg_orcrdb_internal. Object names with these prefixes are reserved for system catalogs.
- User and role names share the same namespace and must be unique.
Role options
| Role option | Description | 
|---|---|
| BYPASSRLS/NOBYPASSRLS | : Allow or disallow a role to bypass row-level security (RLS) policies on a table. This option controls the access from an RLS perspective only; the user also needs sufficient GRANTprivileges to read or write to the table. | 
| CANCELQUERY/NOCANCELQUERY | Deprecated in v22.2: Use the CANCELQUERYsystem privilege. Allow or disallow a role to cancel queries and sessions of other roles. Without this role option, roles can only cancel their own queries and sessions. Even with theCANCELQUERYrole option, non-adminroles cannot canceladminqueries or sessions. This option should usually be combined withVIEWACTIVITYso that the role can view other roles' query and session information.By default, the role option is set to NOCANCELQUERYfor all non-adminroles. | 
| CONTROLCHANGEFEED/NOCONTROLCHANGEFEED | Deprecated in v23.1: Use the CHANGEFEEDprivilege. Allow or disallow a role to runCREATE CHANGEFEEDon tables they haveSELECTprivileges on.By default, the role option is set to NOCONTROLCHANGEFEEDfor all non-adminroles. | 
| CONTROLJOB/NOCONTROLJOB | Allow or disallow a role to pause, resume, and cancel jobs. Non- adminroles cannot control jobs created byadminroles.By default, the role option is set to NOCONTROLJOBfor all non-adminroles. | 
| CREATEDB/NOCREATEDB | Allow or disallow a role to create or rename a database. The role is assigned as the owner of the database. By default, the role option is set to NOCREATEDBfor all non-adminroles. | 
| CREATELOGIN/NOCREATELOGIN | Allow or disallow a role to manage authentication using the WITH PASSWORD,VALID UNTIL, andLOGIN/NOLOGINrole options.By default, the role option is set to NOCREATELOGINfor all non-adminroles. | 
| CREATEROLE/NOCREATEROLE | Allow or disallow the new role to create, alter, and drop other non- adminroles.By default, the role option is set to NOCREATEROLEfor all non-adminroles. | 
| LOGIN/NOLOGIN | Allow or disallow a role to log in with one of the client authentication methods. Setting the role option to NOLOGINprevents the role from logging in using any authentication method. | 
| MODIFYCLUSTERSETTING/NOMODIFYCLUSTERSETTING | Allow or disallow a role to modify the cluster settings with the sql.defaultsprefix.By default, the role option is set to NOMODIFYCLUSTERSETTINGfor all non-adminroles. | 
| PASSWORD password/PASSWORD NULL | The credential the role uses to authenticate their access to a secure cluster. A password should be entered as a string literal. For compatibility with PostgreSQL, a password can also be entered as an identifier. To prevent a role from using password authentication and to mandate certificate-based client authentication, set the password as NULL. | 
| SQLLOGIN/NOSQLLOGIN | Deprecated in v22.2: Use the NOSQLLOGINsystem privilege. Allow or disallow a role to log in using the SQL CLI with one of the client authentication methods. The role option toNOSQLLOGINprevents the role from logging in using the SQL CLI with any authentication method while retaining the ability to log in to DB Console. It is possible to have bothNOSQLLOGINandLOGINset for a role andNOSQLLOGINtakes precedence on restrictions.Without any role options all login behavior is permitted. | 
| VALID UNTIL | The date and time (in the timestampformat) after which the password is not valid. | 
| VIEWACTIVITY/NOVIEWACTIVITY | Deprecated in v22.2: Use the VIEWACTIVITYsystem privilege. Allow or disallow a role to see other roles' queries and sessions usingSHOW STATEMENTS,SHOW SESSIONS, and the Statements and Transactions pages in the DB Console.VIEWACTIVITYalso permits visibility of node hostnames and IP addresses in the DB Console. WithNOVIEWACTIVITY, theSHOWcommands show only the role's own data, and DB Console pages redact node hostnames and IP addresses.By default, the role option is set to NOVIEWACTIVITYfor all non-adminroles. | 
| VIEWCLUSTERSETTING/NOVIEWCLUSTERSETTING | Deprecated in v22.2: Use the VIEWCLUSTERSETTINGsystem privilege. Allow or disallow a role to view the cluster settings withSHOW CLUSTER SETTINGor to access the Cluster Settings page in the DB Console.By default, the role option is set to NOVIEWCLUSTERSETTINGfor all non-adminroles. | 
| VIEWACTIVITYREDACTED/NOVIEWACTIVITYREDACTED | Deprecated in v22.2: Use the VIEWACTIVITYREDACTEDsystem privilege. Allow or disallow a role to see other roles' queries and sessions usingSHOW STATEMENTS,SHOW SESSIONS, and the Statements and Transactions pages in the DB Console. WithVIEWACTIVITYREDACTED, a user will not have access to the usage of statements diagnostics bundle (which can contain PII information) in the DB Console, and will not be able to list queries containing constants for other users when using thelistSessionsendpoint through the Cluster API. It is possible to have bothVIEWACTIVITYandVIEWACTIVITYREDACTED, andVIEWACTIVITYREDACTEDtakes precedence on restrictions. If the user hasVIEWACTIVITYbut doesn't haveVIEWACTIVITYREDACTED, they will be able to see DB Console pages and have access to the statements diagnostics bundle.By default, the role option is set to NOVIEWACTIVITYREDACTEDfor all non-adminroles. | 
Examples
To run the following examples, start a secure single-node cluster and use the built-in SQL shell:
$ cockroach sql --certs-dir=certs
> SHOW ROLES;
username | options | member_of | estimated_last_login_time
---------+---------+-----------+------------------------------
admin    | {}      | {}        | NULL
root     | {}      | {admin}   | NULL
(2 rows)
The following statements are run by the root user that is a member of the admin role and has ALL privileges.
Create a role
Role names are case-insensitive; must start with a letter, number, or underscore; must contain only letters, numbers, periods, or underscores; and must be between 1 and 63 characters.
CREATE ROLE no_options;
SHOW ROLES;
username   | options   | member_of | estimated_last_login_time
-----------+-----------+-----------+------------------------------
admin      | {}        | {}        | NULL
no_options | {NOLOGIN} | {}        | NULL
root       | {}        | {admin}   | NULL
(3 rows)
After creating roles, you must grant them privileges to databases.
Create a role that can log in to the database
CREATE ROLE can_login WITH LOGIN PASSWORD '$tr0nGpassW0rD' VALID UNTIL '2021-10-10';
SHOW ROLES;
 username  |                     options                     | member_of | estimated_last_login_time
-----------+-------------------------------------------------+-----------+------------------------------
admin      | {}                                              | {}        | NULL
can_login  | {VALID UNTIL=2025-10-10 00:00:00+00:00}         | {}        | NULL
no_options | {NOLOGIN}                                       | {}        | NULL
root       | {}                                              | {admin}   | NULL
(4 rows)
Prevent a role from using password authentication
The following statement prevents the role from using password authentication and mandates certificate-based client authentication:
CREATE ROLE no_password WITH PASSWORD NULL;
SHOW ROLES;
 username  |                     options                     | member_of | estimated_last_login_time
-----------+-------------------------------------------------+-----------+------------------------------
admin      | {}                                              | {}        | NULL
can_login  | {VALID UNTIL=2025-10-10 00:00:00+00:00}         | {}        | NULL
no_options | {NOLOGIN}                                       | {}        | NULL
no_password| {NOLOGIN}                                       | {}        | NULL
root       | {}                                              | {admin}   | NULL
(5 rows)
Create a role that can create other roles and manage authentication methods for the new roles
The following example allows the role to create other users and manage authentication methods for them:
CREATE ROLE can_create_role WITH CREATEROLE CREATELOGIN;
SHOW ROLES;
   username     |                     options                     | member_of | estimated_last_login_time
----------------+-------------------------------------------------+-----------+------------------------------
admin           | {}                                              | {}        | NULL
can_create_role | {CREATELOGIN,CREATEROLE,NOLOGIN}                | {}        | NULL
can_login       | {VALID UNTIL=2025-10-10 00:00:00+00:00}         | {}        | NULL
no_options      | {NOLOGIN}                                       | {}        | NULL
no_password     | {NOLOGIN}                                       | {}        | NULL
root            | {}                                              | {admin}   | NULL
(6 rows)
Create a role that can create and rename databases
The following example allows the role to create or rename databases:
CREATE ROLE can_create_db WITH CREATEDB;
SHOW ROLES;
      username        |                     options                     | member_of | estimated_last_login_time
----------------------+-------------------------------------------------+-----------+------------------------------
admin                 | {}                                              | {}        | NULL
can_create_db         | {CREATEDB,NOLOGIN}                              | {}        | NULL
can_create_role       | {CREATELOGIN,CREATEROLE,NOLOGIN}                | {}        | NULL
can_login             | {VALID UNTIL=2025-10-10 00:00:00+00:00}         | {}        | NULL
no_options            | {NOLOGIN}                                       | {}        | NULL
no_password           | {NOLOGIN}                                       | {}        | NULL
root                  | {}                                              | {admin}   | NULL
(7 rows)
Create a role that can pause, resume, and cancel non-admin jobs
The following example allows the role to pause, resume, and cancel jobs:
CREATE ROLE can_control_job WITH CONTROLJOB;
SHOW ROLES;
      username        |                     options                     | member_of | estimated_last_login_time
----------------------+-------------------------------------------------+-----------+------------------------------
admin                 | {}                                              | {}        | NULL
can_control_job       | {CONTROLJOB,NOLOGIN}                            | {}        | NULL
can_create_db         | {CREATEDB,NOLOGIN}                              | {}        | NULL
can_create_role       | {CREATELOGIN,CREATEROLE,NOLOGIN}                | {}        | NULL
can_login             | {VALID UNTIL=2025-10-10 00:00:00+00:00}         | {}        | NULL
manage_auth_for_roles | {CREATELOGIN,NOLOGIN}                           | {}        | NULL
no_options            | {NOLOGIN}                                       | {}        | NULL
no_password           | {NOLOGIN}                                       | {}        | NULL
root                  | {}                                              | {admin}   | NULL
(8 rows)
Create a role that can see and cancel non-admin queries and sessions
The following example allows the role to cancel queries and sessions for other non-admin roles:
CREATE ROLE can_manage_queries WITH CANCELQUERY VIEWACTIVITY;
SHOW ROLES;
      username        |                     options                     | member_of | estimated_last_login_time
----------------------+-------------------------------------------------+-----------+------------------------------
admin                 | {}                                              | {}        | NULL
can_control_job       | {CONTROLJOB,NOLOGIN}                            | {}        | NULL
can_create_db         | {CREATEDB,NOLOGIN}                              | {}        | NULL
can_create_role       | {CREATELOGIN,CREATEROLE,NOLOGIN}                | {}        | NULL
can_login             | {VALID UNTIL=2025-10-10 00:00:00+00:00}         | {}        | NULL
can_manage_queries    | {CANCELQUERY,NOLOGIN,VIEWACTIVITY}              | {}        | NULL
no_options            | {NOLOGIN}                                       | {}        | NULL
no_password           | {NOLOGIN}                                       | {}        | NULL
root                  | {}                                              | {admin}   | NULL
(9 rows)
Create a role that can control changefeeds
The following example allows the role to run CREATE CHANGEFEED:
CREATE ROLE can_control_changefeed WITH CONTROLCHANGEFEED;
SHOW ROLES;
       username        |                     options                     | member_of | estimated_last_login_time
-----------------------+-------------------------------------------------+-----------+------------------------------
admin                  | {}                                              | {}        | NULL
can_control_changefeed | {CONTROLCHANGEFEED,NOLOGIN}                     | {}        | NULL
can_control_job        | {CONTROLJOB,NOLOGIN}                            | {}        | NULL
can_create_db          | {CREATEDB,NOLOGIN}                              | {}        | NULL
can_create_role        | {CREATELOGIN,CREATEROLE,NOLOGIN}                | {}        | NULL
can_login              | {VALID UNTIL=2025-10-10 00:00:00+00:00}         | {}        | NULL
can_manage_queries     | {CANCELQUERY,NOLOGIN,VIEWACTIVITY}              | {}        | NULL
no_options             | {NOLOGIN}                                       | {}        | NULL
no_password            | {NOLOGIN}                                       | {}        | NULL
root                   | {}                                              | {admin}   | NULL
(10 rows)
Create a role that can modify cluster settings
The following example allows the role to modify cluster settings:
CREATE ROLE can_modify_cluster_setting WITH MODIFYCLUSTERSETTING;
SHOW ROLES;
         username          |                     options                     | member_of | estimated_last_login_time
---------------------------+-------------------------------------------------+-----------+------------------------------
admin                      | {}                                              | {}        | NULL
can_control_changefeed     | {CONTROLCHANGEFEED,NOLOGIN}                     | {}        | NULL
can_control_job            | {CONTROLJOB,NOLOGIN}                            | {}        | NULL
can_create_db              | {CREATEDB,NOLOGIN}                              | {}        | NULL
can_create_role            | {CREATELOGIN,CREATEROLE,NOLOGIN}                | {}        | NULL
can_login                  | {VALID UNTIL=2025-10-10 00:00:00+00:00}         | {}        | NULL
can_manage_queries         | {CANCELQUERY,NOLOGIN,VIEWACTIVITY}              | {}        | NULL
can_modify_cluster_setting | {MODIFYCLUSTERSETTING,NOLOGIN}                  | {}        | NULL
no_options                 | {NOLOGIN}                                       | {}        | NULL
no_password                | {NOLOGIN}                                       | {}        | NULL
root                       | {}                                              | {admin}   | NULL
(11 rows)
Create a role that can bypass row-level security (RLS)
To create a role that can bypass row-level security, execute the following statement to grant the BYPASSRLS privilege:
CREATE ROLE can_bypassrls WITH BYPASSRLS;
For instructions showing how to alter a role to add or remove the BYPASSRLS privilege, refer to ALTER ROLE.
Set the SUBJECT role option for certificate based authentication
You can associate an X.509 certificate's Subject with a role as shown below. Note that the Subject fields in the certificate have to be an exact match with what you pass in via the SQL statement. By exact match, we mean that the order of attributes passed in via the SQL statement must match the order of attributes in the certificate.
CREATE ROLE maxroach WITH SUBJECT 'CN=myName,OU=myOrgUnit,O=myOrg,L=myLocality,ST=myState,C=myCountry' LOGIN;
If you manage your own Certificate Authority (CA) infrastructure, CockroachDB supports mapping between the Subject field of your X.509 certificates and SQL roles. For more information, see Certificate-based authentication using multiple values from the X.509 Subject field.