Cassandra Query Language (CQL) for Astra DB
Because Astra DB Serverless is powered by Apache Cassandra®, you can send Cassandra Query Language (CQL) queries to your Astra DB Serverless databases with cqlsh, Cassandra drivers, or the Data API.
To use CQL for Astra DB, you need an active Astra DB Serverless database with a keyspace. Familiarity with CQL is helpful but not required.
For more information about CQL for Astra DB, including command examples and specifications, see the CQL for Astra DB reference.
Limitations on CQL for Astra DB
To ensure high availability and optimum performance, Astra DB Serverless databases have guardrails on underlying Apache Cassandra® functionality, including commands and functionality available through CQL for Astra DB.
Keyspace, table, and column names are case sensitive
If you create a table in the Astra Portal, the table name, keyspace name, and column names become case-sensitive. Make sure your CQL commands use case sensitivity for these values. For more information, see How do I fix a "table does not exist" error in CQL.
Unsupported values are ignored
If you pass a CQL statement with unsupported data definition language (DDL) properties, the statement is executed without the unsupported values. Astra DB ignores the unsupported values and throws a warning.
For example, the following command creates a table with the given schema, and it attempts to pass an additional nodesync property:
CREATE TABLE IF NOT EXISTS library.books
  (
    id UUID PRIMARY KEY,
    lastname text,
    firstname text)
  WITH nodesync={'enabled': 'true'};If you execute this statement against an Astra DB database, the table is created but the nodesync property is ignored.
The response includes a warning with the ignored unsupported values:
Warnings :
Ignoring provided values [nodesync] as they are not supported for Table
Properties(ignored values are: [additional_write_policy,
bloom_filter_fp_chance, caching, cdc, compaction, compression,
crc_check_chance, dse_edge_label_property, dse_vertex_label_property,
gc_grace_seconds, id, max_index_interval, memtable,
memtable_flush_period_in_ms, min_index_interval, nodesync, read_repair,
speculative_retry])Limited support for user-defined objects
CQL for Astra DB supports user-defined type (UDTs) when interacting through cqlsh or a driver.
The Data API also supports UDTs.
CQL for Astra DB doesn’t support user-defined functions (UDFs) or user-defined aggregate functions (UDAs).
Unsupported CQL commands
CQL for Astra DB doesn’t support operations on the following:
- 
Access control 
- 
DSE Search indexes 
- 
Keyspaces (except DESCRIBE KEYSPACE)
- 
Materialized views 
- 
Triggers 
- 
User-defined aggregates 
- 
User-defined functions 
List of CQL commands that aren’t supported for Astra DB
- 
CREATE KEYSPACE
- 
ALTER KEYSPACE
- 
DROP KEYSPACE
- 
CREATE MATERIALIZED VIEW
- 
ALTER MATERIALIZED VIEW
- 
DROP MATERIALIZED VIEW
- 
CREATE AGGREGATE
- 
DESCRIBE AGGREGATE
- 
DROP AGGREGATE
- 
CREATE FUNCTION
- 
DESCRIBE FUNCTION
- 
DROP FUNCTION
- 
CREATE TRIGGER
- 
DROP TRIGGER
- 
CREATE ROLE
- 
GRANT ROLE
- 
ALTER ROLE
- 
REVOKE ROLE
- 
DROP ROLE
- 
LIST ROLES
- 
GRANT PERMISSION
- 
LIST PERMISSIONS
- 
REVOKE PERMISSION
- 
RESTRICT
- 
RESTRICT ROWS
- 
UNRESTRICT
- 
UNRESTRICT ROWS
- 
CREATE SEARCH INDEX
- 
COMMIT SEARCH INDEX
- 
REBUILD SEARCH INDEX
- 
RELOAD SEARCH INDEX
- 
ALTER SEARCH INDEX SCHEMA
- 
ALTER SEARCH INDEX CONFIG
- 
DROP SEARCH INDEX CONFIG
For information about keyspaces and access control in Astra, see Manage keyspaces and Manage roles and permissions.
For a list of supported CQL commands, see the CQL for Astra DB quick reference.
Execute CQL statements
To run CQL statements against your Astra DB Serverless databases, you can use cqlsh, a driver, or the Data API.
Data API and clients
You can use the Data API and clients to manage tables in Serverless (Vector) databases, including tables you created through cqlsh or a driver.
For more information, see Get started with the Data API and About tables with the Data API.
Drivers
Astra DB is compatible with the following drivers:
| Language | Driver | Version | Documentation | 
|---|---|---|---|
| C++ | |||
| C# | |||
| Go | |||
| Java | |||
| Node.js | |||
| Python | |||
| Scala | Connect to Astra DB Serverless with the Apache Cassandra Spark connector | 
For more information, see Connect to a database: Drivers.
cqlsh
The Cassandra Query Language Shell (cqlsh) is a utility that you can use to issue CQL commands to your Astra DB Serverless database.
You can use the embedded cqlsh in the Astra Portal or standalone cqlsh.
- 
Embedded cqlsh 
- 
Standalone cqlsh 
The Astra Portal provides an embedded cqlsh instance, known as the CQL Console, for each Astra DB Serverless database.
You can use the CQL Console to run CQL commands on your databases directly from your browser.
- 
In the Astra Portal, click the name of the database that you want to access. 
- 
Click CQL Console to open the CQL Console in a new tab. 
- 
Wait for the token@cqlsh>prompt to appear.This prompt indicates that the CQL Console is connected to your database, and you can begin issuing CQL commands to your database. 
- 
Optional: For multi-region databases, you can use the region menu to access data from a secondary region. However, due to Astra DB’s eventual consistency model, changes to data in any region are eventually replicated to the database’s other regions. 
The standalone cqlsh is a separate, lightweight utility that you can use to interact with your database.
| You can use the Astra CLI to download and configure the standalone  | 
- 
Install Python version 2.7.12 or later with TLS support. 
- 
Download the SCB for your database. For multi-region databases, if you want to access data from a secondary region, you must download the SCB for that specific region. However, due to Astra DB’s eventual consistency model, changes to data in any region are eventually replicated to the database’s other regions. 
- 
Download cqlsh for your Astra DB Serverless database: - 
DataStax Astra 
- 
DataStax Astra with support for Vector Type. 
 
- 
- 
Change to the directory where you downloaded the cqlshpackage:cd /DOWNLOAD_DIRECTORY
- 
Extract the files: tar -xvf cqlsh-astra-DATE-bin.tar.gzReplace DATEwith the package release date, such as20210304.
- 
Run the cqlshscript:cd /cqlsh-astra ./bin/cqlsh -u CLIENT_ID -p CLIENT_SECRET -b PATH/TO/SCB.zipReplace the following: - 
PATH/TO/SCB.zip: The path to your database’s SCB zip file
- 
CLIENT_IDandCLIENT_SECRET: Either of the following sets of values from your application token:- 
The clientIdvalue and thesecretvalue
- 
The literal string tokenand the token itself (prefixed byAstraCS:)
 
- 
 Optional: Store credentials in thecqlshrcfileIf you don’t want to pass the credentials on the command line every time, you can configure the location in your cqlshrcfile:- 
In the ~/.cassandradirectory, open thecqlshrcfile.
- 
In the [authentication]section, add theCLIENT_IDandCLIENT_SECRETvalues from your application token.
- 
In the [connection]section, add the path to the SCB.
 [authentication] username = CLIENT_ID # or the literal stringtokenpassword = CLIENT_SECRET # or the token secret prefixed by 'AstraCS:' [connection] secure_connect_bundle = PATH/TO/SCB.zip
- 
- 
Make sure the command returns output indicating that you connected to your database. For example: [cqlsh 6.8.0 | DSE 6.8.0.77 | CQL spec 3.4.5 | DSE protocol v2] Use HELP for help. username@cqlsh>
CQL for Astra DB documentation and examples
For general information about CQL, including CQL for Astra DB, see the following:
