Skip to main content

Interface to the SingleStoreDB database and workspace management APIs

Project description

SingleStoreDB Python SDK

The SingleStoreDB Python SDK provides a DB-API 2.0 compatible interface to SingleStore, a high-performance distributed SQL database designed for data-intensive applications including real-time analytics and vector search.

Key Features:

  • High Performance: Includes a C extension that delivers up to 10x faster data reading compared to pure Python MySQL connectors
  • Multiple Protocols: Connect via MySQL protocol (port 3306) or HTTP Data API (port 9000) using the same interface
  • Flexible Result Formats: Return query results as tuples, dictionaries, named tuples, NumPy arrays, Pandas DataFrames, Polars DataFrames, or PyArrow Tables
  • Workspace Management: Full API for managing SingleStore Cloud workspaces, clusters, regions, and files programmatically
  • Vector Store: Pinecone-compatible vector database API for similarity search applications with built-in connection pooling
  • User-Defined Functions: Deploy Python functions as SingleStore UDFs with automatic type mapping (HTTP/ASGI or plugin-mode via CLI)
  • SQLAlchemy Support: Integrate with SQLAlchemy through the optional sqlalchemy-singlestoredb adapter
  • Fusion SQL: Extend SQL with custom client-side command handlers

Install

This package can be installed from PyPI using pip:

pip install singlestoredb

Optional Dependencies

The SDK has several optional dependencies for additional functionality:

# Vector store support (Pinecone-compatible API)
pip install 'singlestoredb[vectorstore]'

# SQLAlchemy integration
pip install 'singlestoredb[sqlalchemy]'

# dbt adapter
pip install 'singlestoredb[dbt]'

# Kerberos/GSSAPI authentication
pip install 'singlestoredb[kerberos]'

# RSA key authentication
pip install 'singlestoredb[rsa]'

# Ed25519 key authentication
pip install 'singlestoredb[ed22519]'

# Pytest plugin with Docker test containers
pip install 'singlestoredb[pytest,docker]'

# Multiple extras can be combined
pip install 'singlestoredb[vectorstore,sqlalchemy]'
Extra Description
vectorstore Vector database functionality via singlestore-vectorstore
sqlalchemy SQLAlchemy dialect via sqlalchemy-singlestoredb
ibis / dataframe Ibis dataframe interface (SingleStore is natively supported in Ibis)
dbt dbt adapter via dbt-singlestore
kerberos / gssapi Kerberos/GSSAPI authentication support
rsa RSA key exchange for encrypted connections
ed22519 Ed25519 key authentication
docker Docker SDK for automated test container management
pytest Pytest plugin with SingleStoreDB Docker test fixtures

Documentation

https://singlestore-labs.github.io/singlestoredb-python

Usage

Connections to the SingleStore database are made using the DB-API parameters host, port, user, password, etc, but they may also be done using URLs that specify these parameters as well (much like the SQLAlchemy package).

import singlestoredb as s2

# Connect using the default connector
conn = s2.connect('user:password@host:3306/db_name')

# Create a cursor
cur = conn.cursor()

# Execute SQL
cur.execute('select * from foo')

# Fetch the results
print(cur.description)
for item in cur:
    print(item)

# Close the connection
conn.close()

Connecting to the HTTP API is done as follows:

# Use the HTTP API connector
conn = s2.connect('https://user:password@host:8080/db_name')

Configuration

Connection parameters can be set through environment variables, programmatically, or via URL. Environment variables are useful for keeping credentials out of code.

Environment Variables

Key environment variables include:

  • SINGLESTOREDB_URL: Full connection URL
  • SINGLESTOREDB_HOST: Database hostname
  • SINGLESTOREDB_PORT: Database port
  • SINGLESTOREDB_USER: Username
  • SINGLESTOREDB_PASSWORD: Password
  • SINGLESTOREDB_DATABASE: Default database name
  • SINGLESTOREDB_PURE_PYTHON: Set to 1 to disable C acceleration

Programmatic Configuration

Options can be set and retrieved using get_option, set_option, and option_context:

import singlestoredb as s2

# Get current option value
current_host = s2.get_option('host')

# Set an option
s2.set_option('results_type', 'pandas')

# Temporarily override options using a context manager
with s2.option_context('results_type', 'dicts'):
    conn = s2.connect()
    # results will be returned as dicts within this block

Result Formats

Query results can be returned in various formats using the results_type parameter or option. Supported formats include:

  • tuples (default): Standard Python tuples
  • namedtuples: Named tuples with column names as attributes
  • dicts: Dictionaries with column names as keys
  • numpy: NumPy arrays
  • pandas: Pandas DataFrames
  • polars: Polars DataFrames
  • arrow: PyArrow Tables
import singlestoredb as s2

conn = s2.connect('user:password@host/db_name')
cur = conn.cursor()

# Return results as dictionaries
cur.execute('SELECT * FROM customers', results_type='dicts')
for row in cur:
    print(row['customer_name'])

# Return results as a Pandas DataFrame
cur.execute('SELECT * FROM customers', results_type='pandas')
df = cur.fetchone()

Management API

The SDK provides a workspace management API for managing SingleStore deployments programmatically. This includes creating and managing workspaces, clusters, regions, and files.

import singlestoredb as s2

# Get a workspace manager (uses SINGLESTOREDB_MANAGEMENT_TOKEN env var by default)
manager = s2.manage_workspaces()

# List all workspaces
for ws in manager.workspaces:
    print(ws.name, ws.state)

# Create a new workspace
ws = manager.workspaces.create(
    name='my-workspace',
    workspace_group_id='<group-id>',
)

See the API documentation for full details on workspace, cluster, region, and file management.

Vector Store

The SDK includes vector database functionality for similarity search applications. This requires the singlestore-vectorstore package.

import singlestoredb as s2

# Create a vector database connection with connection pooling
vdb = s2.vector_db(
    'user:password@host/db_name',
    pool_size=5,       # Number of connections in pool
    max_overflow=10,   # Maximum extra connections
    timeout=30,        # Connection acquisition timeout
)

# Use vector operations
index = vdb.get_or_create_index('my_index', dimension=768)

The vector_db function returns a VectorDB instance that provides Pinecone-compatible operations for vector similarity search.

Fusion SQL

Fusion SQL extends the SQL commands handled by the client with custom handlers. These commands are processed locally rather than sent to the database server. Built-in handlers provide SQL-like commands for managing workspaces, running notebook jobs, and more.

import os
os.environ['SINGLESTOREDB_FUSION_ENABLED'] = '1'

import singlestoredb as s2
conn = s2.connect()

# Show available cloud regions
conn.execute('SHOW REGIONS')

# List workspace groups
conn.execute('SHOW WORKSPACE GROUPS')

# List workspaces in a specific group
conn.execute("SHOW WORKSPACES IN GROUP 'my-group' EXTENDED")

# Create a new workspace group
conn.execute("""
    CREATE WORKSPACE GROUP 'analytics-team'
    IN REGION 'US West 2 (Oregon)'
    WITH PASSWORD 'my-password'
    WITH FIREWALL RANGES '10.0.0.0/8'
""")

See singlestoredb/fusion/README.md for details on writing custom Fusion SQL handlers.

Pytest Plugin

The SDK includes a pytest plugin that automatically manages SingleStoreDB Docker containers for integration testing. Install with:

pip install 'singlestoredb[pytest,docker]'

The plugin provides these fixtures:

  • singlestoredb_test_container (session-scoped): Starts and stops a SingleStoreDB Dev container, or reuses an existing server if SINGLESTOREDB_URL is set
  • singlestoredb_connection (session-scoped): Database connection to the test container
  • singlestoredb_tempdb (function-scoped): Cursor with a fresh temporary database, dropped after the test

The plugin supports pytest-xdist parallel execution with leader/follower coordination for container lifecycle.

def test_query(singlestoredb_tempdb):
    singlestoredb_tempdb.execute('CREATE TABLE t (id INT)')
    singlestoredb_tempdb.execute('INSERT INTO t VALUES (1)')
    singlestoredb_tempdb.execute('SELECT * FROM t')
    assert singlestoredb_tempdb.fetchone() == (1,)

Plugin UDF Server

The SDK ships a high-performance plugin-mode UDF server that runs as a standalone process, communicating with SingleStoreDB over a Unix socket.

# Via the installed CLI entry point
python-udf-server --plugin-name myfuncs --search-path /path/to/modules

# Or as a Python module
python -m singlestoredb.functions.ext.plugin --plugin-name myfuncs
Option Env Variable Default Description
--plugin-name PLUGIN_NAME (required) Python module to import
--search-path PLUGIN_SEARCH_PATH "" Colon-separated module search dirs
--socket PLUGIN_SOCKET_PATH auto-generated Unix socket path
--n-workers PLUGIN_N_WORKERS 0 (CPU count) Worker threads/processes
--max-connections PLUGIN_MAX_CONNECTIONS 32 Socket backlog
--log-level PLUGIN_LOG_LEVEL info Logging level
--process-mode PLUGIN_PROCESS_MODE process thread or process concurrency

Advanced Options

SSL/TLS Configuration

SSL connections can be configured using connection parameters or environment variables:

conn = s2.connect(
    'user:password@host/db_name',
    ssl_ca='/path/to/ca.pem',
    ssl_cert='/path/to/client-cert.pem',
    ssl_key='/path/to/client-key.pem',
)

Other Connection Options

conn = s2.connect(
    'user:password@host/db_name',

    # Performance options
    pure_python=False,          # Set True to disable C acceleration
    buffered=True,              # Buffer entire result set in memory

    # Data handling
    autocommit=True,            # Enable autocommit mode
    local_infile=True,          # Allow LOAD DATA LOCAL INFILE
    nan_as_null=True,           # Treat NaN as NULL in parameters
    inf_as_null=True,           # Treat Inf as NULL in parameters

    # Extended types
    enable_extended_data_types=True,  # Enable BSON and vector types
    vector_data_format='binary',      # Vector format: 'json' or 'binary'

    # Connection behavior
    connect_timeout=10,         # Connection timeout in seconds
    multi_statements=True,      # Allow multiple statements per query
)

Performance

While this package is based on PyMySQL which is a pure Python-based MySQL connector, it adds various performance enhancements that make it faster than most other connectors. The performance improvements come from changes to the data conversion functions, cursor implementations, and a C extension that is highly optimized to improve row data reading.

The package can be used both in a pure Python mode and as well as a C accelerated mode. Generally speaking, the C accelerated version of the client can read data 10X faster than PyMySQL, 2X faster than MySQLdb, and 1.5X faster than mysql.connector. All of this is done without having to install any 3rd party MySQL libraries!

Benchmarking was done with a table of 3,533,286 rows each containing a datetime, a float, and eight character columns. The data is the same data set used in this article. The client and server were running on the same machine and queries were made using fetchone, fetchall, fetchmany(1000), and an iterator over the cursor object (e.g., iter(cur)). The results are shown below.

Buffered

PyMySQL MySQLdb mysql.connector SingleStore (pure Python) SingleStore
fetchall 37.0s 8.7s 5.6s 29.0s 3.7s
fetchmany(1000) 37.4s 9.2s 6.2s 29.6s 3.6s
fetchone 38.2s 10.1s 10.2s 30.9s 4.8s
iter(cur) 38.3s 9.1s 10.2s 30.4s 4.4s

Unbuffered

PyMySQL MySQLdb mysql.connector SingleStore (pure Python) SingleStore
fetchall 39.0s 6.5s 5.5s 30.3s 5.5s
fetchmany(1000) 39.4s 7.0s 6.0s 30.4s 4.1s
fetchone 34.5s 8.9s 10.1s 30.8s 6.6s
iter(cur) 39.0s 9.0s 10.2s 31.4s 6.0s

License

This library is licensed under the Apache 2.0 License.

Resources

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

singlestoredb-1.17.0.tar.gz (426.3 kB view details)

Uploaded Source

Built Distributions

If you're not sure about the file name format, learn more about wheel file names.

singlestoredb-1.17.0-py3-none-any.whl (470.4 kB view details)

Uploaded Python 3

singlestoredb-1.17.0-cp38-abi3-win_amd64.whl (508.2 kB view details)

Uploaded CPython 3.8+Windows x86-64

singlestoredb-1.17.0-cp38-abi3-win32.whl (510.5 kB view details)

Uploaded CPython 3.8+Windows x86

singlestoredb-1.17.0-cp38-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (1.1 MB view details)

Uploaded CPython 3.8+manylinux: glibc 2.17+ x86-64

singlestoredb-1.17.0-cp38-abi3-manylinux_2_17_aarch64.manylinux2014_aarch64.whl (1.1 MB view details)

Uploaded CPython 3.8+manylinux: glibc 2.17+ ARM64

singlestoredb-1.17.0-cp38-abi3-macosx_10_9_universal2.whl (541.5 kB view details)

Uploaded CPython 3.8+macOS 10.9+ universal2 (ARM64, x86-64)

File details

Details for the file singlestoredb-1.17.0.tar.gz.

File metadata

  • Download URL: singlestoredb-1.17.0.tar.gz
  • Upload date:
  • Size: 426.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for singlestoredb-1.17.0.tar.gz
Algorithm Hash digest
SHA256 97cea09c15e93003e772b3e167e498cb25f7afb6ce2dc539ac74a1f1862c4fbd
MD5 93e2a4344b048b25bd7a2f0d85da1195
BLAKE2b-256 b35fe52da936f4c13e8f07366a190e12fbd02c1f2fa724107e6394af5abb49d8

See more details on using hashes here.

Provenance

The following attestation bundles were made for singlestoredb-1.17.0.tar.gz:

Publisher: publish.yml on singlestore-labs/singlestoredb-python

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file singlestoredb-1.17.0-py3-none-any.whl.

File metadata

  • Download URL: singlestoredb-1.17.0-py3-none-any.whl
  • Upload date:
  • Size: 470.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for singlestoredb-1.17.0-py3-none-any.whl
Algorithm Hash digest
SHA256 7bf1d5450d1b5d6cdf84cd4c9ecae5c778a64d5a5edb33dda8c3ae77d9a9d648
MD5 b7ef563ea48feeaeb80d59d2a5894bba
BLAKE2b-256 2e1f2cae0fc39a3941773e7d6d9f7b522be5f840dfc7990c39e4d18198a58538

See more details on using hashes here.

Provenance

The following attestation bundles were made for singlestoredb-1.17.0-py3-none-any.whl:

Publisher: publish.yml on singlestore-labs/singlestoredb-python

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file singlestoredb-1.17.0-cp38-abi3-win_amd64.whl.

File metadata

File hashes

Hashes for singlestoredb-1.17.0-cp38-abi3-win_amd64.whl
Algorithm Hash digest
SHA256 01db9048a0cd1b85a7b15b1d9d4b404eaf14c6aefa1ea14e952b61f3279752e1
MD5 7870dd07cb6ce0254d09dde0a899805d
BLAKE2b-256 81d885232f3cad48f1b54241150ab9e2e14baaded9ebcc361f33825c982d49de

See more details on using hashes here.

Provenance

The following attestation bundles were made for singlestoredb-1.17.0-cp38-abi3-win_amd64.whl:

Publisher: publish.yml on singlestore-labs/singlestoredb-python

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file singlestoredb-1.17.0-cp38-abi3-win32.whl.

File metadata

  • Download URL: singlestoredb-1.17.0-cp38-abi3-win32.whl
  • Upload date:
  • Size: 510.5 kB
  • Tags: CPython 3.8+, Windows x86
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for singlestoredb-1.17.0-cp38-abi3-win32.whl
Algorithm Hash digest
SHA256 cf7073d79b7f32757d136bfc88c388f595e9ad24a1e002ab0827ccded3b407c4
MD5 f6a287f564a333a2fbd9c528096d7621
BLAKE2b-256 5965792a028087bc5aae9bacb0bbf953feaf1d18c880831f9c378d029351048c

See more details on using hashes here.

Provenance

The following attestation bundles were made for singlestoredb-1.17.0-cp38-abi3-win32.whl:

Publisher: publish.yml on singlestore-labs/singlestoredb-python

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file singlestoredb-1.17.0-cp38-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for singlestoredb-1.17.0-cp38-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 602a4271ca06f652b68ff4d47ae5bbfd26ff4d16e748f66bfecabbc138d56648
MD5 2fa252b91269063bd5a1f6c0fa4d825d
BLAKE2b-256 aa879ad65697a092ef054befc27814328bce5071cfcd91ffb4ff7f9b93c7aaec

See more details on using hashes here.

Provenance

The following attestation bundles were made for singlestoredb-1.17.0-cp38-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl:

Publisher: publish.yml on singlestore-labs/singlestoredb-python

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file singlestoredb-1.17.0-cp38-abi3-manylinux_2_17_aarch64.manylinux2014_aarch64.whl.

File metadata

File hashes

Hashes for singlestoredb-1.17.0-cp38-abi3-manylinux_2_17_aarch64.manylinux2014_aarch64.whl
Algorithm Hash digest
SHA256 51568e337ee43044d61117f92dc996dd601ad6d3115980d15ac519a1af5ec54d
MD5 7aa491949620230a417b6f6f2a42cd25
BLAKE2b-256 479fa44c0ea4b17355acac7f20ce1891ad708c638302f41b8626a29fa82129ed

See more details on using hashes here.

Provenance

The following attestation bundles were made for singlestoredb-1.17.0-cp38-abi3-manylinux_2_17_aarch64.manylinux2014_aarch64.whl:

Publisher: publish.yml on singlestore-labs/singlestoredb-python

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file singlestoredb-1.17.0-cp38-abi3-macosx_10_9_universal2.whl.

File metadata

File hashes

Hashes for singlestoredb-1.17.0-cp38-abi3-macosx_10_9_universal2.whl
Algorithm Hash digest
SHA256 e6b056d7171c6d514ba42d411ec60dfb93effe14bf52c07fb309c1f67397eaac
MD5 79bd399502154386fb920288ee749e0b
BLAKE2b-256 243f322779e04d34fcf233fe4634d8e7c13d94f2ee1e733c78134e7f20191abb

See more details on using hashes here.

Provenance

The following attestation bundles were made for singlestoredb-1.17.0-cp38-abi3-macosx_10_9_universal2.whl:

Publisher: publish.yml on singlestore-labs/singlestoredb-python

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page