Keyspaces
Keyspaces are used to store collections in Hyper-Converged Database (HCD). To manage keyspaces, you must first get a database admin object.
HCD APIs use the term keyspace to refer to both namespaces and keyspaces. |
Keyspaces are the main database objects used to store collections in HCD. It’s a good practice to create a keyspace for each application.
-
Python
-
TypeScript
-
Java
View this topic in more detail on the API Reference.
Create a new keyspace in the database:
database = DataAPIClient(
token=token_provider, environment=Environment.HCD,
).get_database(DB_API_ENDPOINT)
database.get_database_admin().create_keyspace(DB_KEYSPACE)
Create a new keyspace in the database, while setting it as the new working keyspace for the database:
database = DataAPIClient(
token=token_provider, environment=Environment.HCD,
).get_database(DB_API_ENDPOINT)
database.get_database_admin().create_keyspace(
DB_KEYSPACE,
update_db_keyspace=True,
)
Create a new keyspace in the database, explicitly setting its replication options:
database = DataAPIClient(
token=token_provider, environment=Environment.HCD,
).get_database(DB_API_ENDPOINT)
database.get_database_admin().create_keyspace(
DB_KEYSPACE,
replication_options={"class": "SimpleStrategy", "replication_factor": 3},
)
Parameters for get_database_admin
:
Name | Type | Summary |
---|---|---|
token |
|
The authentication token. It can be a string or an instance of an |
Parameters for create_keyspace
:
Name | Type | Summary |
---|---|---|
name |
|
The keyspace name. If supplying a keyspace that exists already, the method call proceeds as usual, no errors are raised, and the whole invocation is a no-op. |
replication_options |
|
This dictionary can specify the options for namespace replication across database nodes. If provided, it must have a structure similar to: |
update_db_keyspace |
|
if True, the Database or AsyncDatabase class that created this DatabaseAdmin is updated to work on the newly-created keyspace when this method returns. |
Returns:
Dict
- A dictionary of the form {"ok": 1}
if the operation succeeds. Otherwise,
an exception is raised.
Example response
{"ok": 1}
Example:
import os
from astrapy import DataAPIClient
from astrapy.authentication import UsernamePasswordTokenProvider
from astrapy.constants import Environment
# Database settings
DB_USERNAME = "cassandra"
DB_PASSWORD = "cassandra"
DB_API_ENDPOINT = "http://localhost:8181"
DB_KEYSPACE = "cycling"
# Prepare a token provider
token_provider = UsernamePasswordTokenProvider(DB_USERNAME, DB_PASSWORD)
# Initialize the client and get a "Database" object
client = DataAPIClient(token=token_provider, environment=Environment.HCD)
database = client.get_database(DB_API_ENDPOINT)
# Create the keyspace; also set it as the working keyspace for the database
database.get_database_admin().create_keyspace(
DB_KEYSPACE,
update_db_keyspace=True,
)
print(database.keyspace == DB_KEYSPACE) # True
The If you were working in a cloud environment such as Astra DB—for example
|
View this topic in more detail on the API Reference.
const dbAdmin = db.admin({ environment: 'hcd' });
(async () => {
await dbAdmin.createKeyspace(DB_KEYSPACE);
console.log(await dbAdmin.listKeyspaces());
})();
Parameters:
Name | Type | Summary |
---|---|---|
name |
|
The name of the keyspace to create. |
options? |
Blocking options regarding the creation of the keyspace. |
Returns:
Promise<void>
- A promise that resolves when the keyspace is created (or when the initial request
completes if not blocking).
Example:
(async () => {
await dbAdmin.createKeyspace(DB_KEYSPACE);
console.log(await dbAdmin.listKeyspaces());
})();
The |
// Create a default keyspace
((DataAPIDatabaseAdmin) client
.getDatabase(dataApiUrl)
.getDatabaseAdmin()).createKeyspace(keyspaceName, KeyspaceOptions.simpleStrategy(1));
Database db = client.getDatabase(dataApiUrl, keyspaceName);
Returns:
None.
Parameters:
Name | Type | Summary |
---|---|---|
keyspaceName |
|
The unique name for the keyspace |
KeyspaceOptions |
|
The replication class and replication factor for the keyspace |
Example:
// Create a default keyspace
((DataAPIDatabaseAdmin) client
.getDatabase(dataApiUrl)
.getDatabaseAdmin()).createKeyspace(keyspaceName, KeyspaceOptions.simpleStrategy(1));
System.out.println("3/7 - Keyspace '" + keyspaceName + "'created ");
Database db = client.getDatabase(dataApiUrl, keyspaceName);
System.out.println("4/7 - Connected to Database");
List keyspaces
Get a list of the keyspace found in a database.
-
Python
-
TypeScript
-
Java
View this topic in more detail on the API Reference.
keyspace = database.get_database_admin().list_keyspaces()
Parameters:
Name | Type | Summary |
---|---|---|
max_time_ms |
|
A timeout, in milliseconds, for the whole requested operation to complete. |
Returns:
List[str]
- A list of the keyspaces with their names appearing in no particular order.
Example response
['cycling', 'food']
Example:
from astrapy import DataAPIClient
from astrapy.authentication import UsernamePasswordTokenProvider
from astrapy.constants import Environment
# Database settings
DB_USERNAME = "cassandra"
DB_PASSWORD = "cassandra"
DB_API_ENDPOINT = "http://localhost:8181"
# Prepare a token provider
token_provider = UsernamePasswordTokenProvider(DB_USERNAME, DB_PASSWORD)
# Initialize the client and get a "Database" object
database = DataAPIClient(
token=token_provider, environment=Environment.HCD,
).get_database(DB_API_ENDPOINT)
# Get a list of the keyspaces in the database
keyspaces = database.get_database_admin().list_keyspaces()
View this topic in more detail on the API Reference.
(async () => {
console.log(await dbAdmin.listKeyspaces());
})();
Returns:
Promise<string[]>
- A list of the keyspaces, with the first keyspace being the default one.
Example:
(async () => {
console.log(await dbAdmin.listKeyspaces());
})();
// List all keyspaces
client.getDatabase(dataApiUrl).getDatabaseAdmin().listKeyspaces().forEach(System.out::println);
Parameters:
None.
Returns:
Name | Type | Summary |
---|---|---|
keyspaces |
|
The list of available keyspaces in current database. |
Example:
// List all keyspaces
client.getDatabase(dataApiUrl).getDatabaseAdmin().listKeyspaces().forEach(System.out::println);
Drop a keyspace
Drop (delete) a keyspace in a database, erasing all data stored in it as well.
-
Python
-
TypeScript
-
Java
View this topic in more detail on the API Reference.
database.get_database_admin().drop_keyspace(DB_KEYSPACE)
Parameters:
Name | Type | Summary |
---|---|---|
name |
|
The keyspace to delete. If it does not exist in this database, an error is raised. |
max_time_ms |
|
A timeout, in milliseconds, for the whole requested operation to complete. Note that a timeout is no guarantee that the deletion request has not reached the API server. |
Returns:
Dict
- A dictionary of the form {"ok": 1}
if the operation succeeds. Otherwise,
an exception is raised.
Example response
{"ok": 1}
Example:
from astrapy import DataAPIClient
from astrapy.authentication import UsernamePasswordTokenProvider
from astrapy.constants import Environment
# Database settings
DB_USERNAME = "cassandra"
DB_PASSWORD = "cassandra"
DB_API_ENDPOINT = "http://localhost:8181"
OLD_DB_KEYSPACE = "cycling_legacy"
# Prepare a token provider
token_provider = UsernamePasswordTokenProvider(DB_USERNAME, DB_PASSWORD)
# Initialize the client and get a "Database" object
database = DataAPIClient(
token=token_provider, environment=Environment.HCD,
).get_database(DB_API_ENDPOINT)
# Drop a keyspace from the database
drop_response = database.get_database_admin().drop_keyspace(OLD_DB_KEYSPACE)
View this topic in more detail on the API Reference.
await dbAdmin.dropKeyspace(DB_KEYSPACE);
console.log('* Keyspace dropped.');
await client.close();
Parameters:
Name | Type | Summary |
---|---|---|
name |
|
The name of the keyspace to drop. |
options? |
Blocking options regarding the deletion of the keyspace. |
Returns:
Promise<void>
- A promise that resolves when the keyspace is deleted (or when the initial request
completes if not blocking).
Example:
// Drop the keyspace
await dbAdmin.dropKeyspace(DB_KEYSPACE);
console.log('* Keyspace dropped.');
await client.close();
The |
((DataAPIDatabaseAdmin) client
.getDatabase(dataApiUrl)
.getDatabaseAdmin()).dropKeyspace(keyspaceName);
Parameters:
Name | Type | Summary |
---|---|---|
keyspace |
|
The name of the keyspace to delete. |
Example:
// Drop the keyspace
((DataAPIDatabaseAdmin) client
.getDatabase(dataApiUrl)
.getDatabaseAdmin()).dropKeyspace(keyspaceName);
System.out.println("8/7 - Keyspace '" + keyspaceName + "' dropped ");