Managing keyspace and table permissions

DataStax Enterprise supports role-based access control to data on transactional nodes. The GRANT and REVOKE CQL commands provide and revoke access to objects and methods. Permission is hierarchical, granting permission to a parent object automatically allows full access to all ancestors; data objects have the following structure:

ALL KEYSPACES
  • KEYSPACE <keyspace_name>

    • TABLE <table_name>

      • '<filtering_string>' ROWS

DataStax Enterprise supports this CQL syntax in cqlsh to grant permissions:

GRANT <permission_name> ON <resource_name> TO <role_name>;

DataStax Enterprise supports this CQL syntax in cqlsh to revoke permissions:

REVOKE <permission_name> ON <resource_name> FROM <role_name>;

Where permissions that apply to each data resources type is described below:

<permission_name> <resource_name> Description

ALTER

ALL KEYSPACES

ALTER KEYSPACE, ALTER TABLE, ALTER TYPE, RESTRICT ROW in any keyspace.

ALTER

KEYSPACE <keyspace_name>

ALTER KEYSPACE, ALTER TABLE, ALTER TYPE, and RESTRICT ROW in specified keyspace.

ALTER

TABLE <table_name>

ALTER TABLE and RESTRICT ROW of specified table.

ALTER

'<filtering_data>' ROWS IN <table_name>

ALTER

CREATE

ALL KEYSPACES

CREATE KEYSPACE, CREATE TABLE, CREATE FUNCTIONS, and CREATE TYPE in any keyspace.

CREATE

KEYSPACE <keyspace_name>

CREATE TABLE and CREATE TYPE in specified keyspace.

DROP

ALL KEYSPACES

DROP KEYSPACE, DROP TABLE, and DROP TYPE in any keyspace

DROP

KEYSPACE <keyspace_name>

DROP TABLE and DROP TYPE in specified keyspace

MODIFY

ALL KEYSPACES

INSERT, UPDATE, DELETE and TRUNCATE rows in any table.

MODIFY

KEYSPACE <keyspace_name>

INSERT, UPDATE, DELETE and TRUNCATE rows in any table in the specified keyspace.

MODIFY

TABLE <table_name>

INSERT, UPDATE, DELETE and TRUNCATE any rows in the specified table. See note for tables with materialized views (MVs).

MODIFY

'<filtering_data>' ROWS IN <table_name>

INSERT, UPDATE, DELETE and TRUNCATE rows that match the 'filtering_data' on rows in a table that match the filtering criteria.

To modify a base table that has a materialized view (MV) using an INSERT or UPDATE command if access permissions are enabled, a user must be granted MODIFY or ALL PERMISSIONS on the base table.

For more details, see Access control matrix.

Procedure

  • Create a role that has all permissions in all keyspaces:

    CREATE ROLE keyspace_admin;
    GRANT ALL PERMISSIONS ON ALL KEYSPACES TO keyspace_admin;
    GRANT keyspace_admin to martin;
  • Create an administrator role for a single keyspace:

    CREATE ROLE cycling_admin;
    GRANT ALL PERMISSIONS ON KEYSPACE cycling to cycling_admin;
    GRANT cycling_admin TO sandy;
  • Create a role that can only make data changes, INSERT, UPDATE, DELETE, and TRUNCATE for any table in the keyspace cycling:

    GRANT MODIFY ON KEYSPACE cycling TO team_manager;
    GRANT team_manager to sandy;
  • Create a role that can only select data and use functions in the cycling keyspace:

    CREATE ROLE cyclist_analyst;
    GRANT SELECT ON KEYSPACE cycling TO cyclist_analyst;
    GRANT EXECUTE ON ALL FUNCTIONS IN KEYSPACE cycling to cyclist_analyst;
    GRANT cyclist_analyst TO wilson;

Was this helpful?

Give Feedback

How can we improve the documentation?

© 2025 DataStax | Privacy policy | Terms of use

Apache, Apache Cassandra, Cassandra, Apache Tomcat, Tomcat, Apache Lucene, Apache Solr, Apache Hadoop, Hadoop, Apache Pulsar, Pulsar, Apache Spark, Spark, Apache TinkerPop, TinkerPop, Apache Kafka and Kafka are either registered trademarks or trademarks of the Apache Software Foundation or its subsidiaries in Canada, the United States and/or other countries. Kubernetes is the registered trademark of the Linux Foundation.

General Inquiries: +1 (650) 389-6000, info@datastax.com