Skip to main content

Turso is a work-in-progress, in-process OLTP database management system, compatible with SQLite.

Project description

Turso Database for Python

PyPI

Chat with other users of Turso on Discord


About

⚠️ Warning: This software is in BETA. It may still contain bugs and unexpected behavior. Use caution with production data and ensure you have backups.

Features

  • SQLite compatible: SQLite query language and file format support (status).
  • In-process: No network overhead, runs directly in your Python process
  • Cross-platform: Supports Linux, macOS, Windows
  • Remote partial sync: Bootstrap from a remote database, pull remote changes, and push local changes when online — all while enjoying a fully operational database offline.
  • Asyncio support: Built-in integration with asyncio to ensure queries won’t block your event loop

Installation

uv pip install pyturso

Database driver

A minimal DB‑API 2.0 example using an in‑memory database:

import turso

# Standard DB-API usage
conn = turso.connect(":memory:")
cur = conn.cursor()

cur.execute("CREATE TABLE users (id INTEGER PRIMARY KEY, username TEXT)")
cur.execute("INSERT INTO users VALUES (1, 'alice'), (2, 'bob')")

cur.execute("SELECT * FROM users ORDER BY id")
rows = cur.fetchall()
print(rows)  # [(1, 'alice'), (2, 'bob')]

conn.close()

Database driver (asyncio)

Non-blocking access with asyncio:

import asyncio
import turso.aio

async def main():
    # Connect and use as an async context manager
    async with turso.aio.connect(":memory:") as conn:
        # Executes multiple statements
        await conn.executescript("""
            CREATE TABLE t (id INTEGER PRIMARY KEY, name TEXT);
            INSERT INTO t(name) VALUES ('alice'), ('bob');
        """)

        # Use a cursor for parameterized queries
        cur = conn.cursor()
        await cur.execute("SELECT COUNT(*) FROM t WHERE name LIKE ?", ("a%",))
        count = (await cur.fetchone())[0]
        print(count)  # 1

        # JSON and generate_series also available
        cur = conn.cursor()
        await cur.execute("SELECT SUM(value) FROM generate_series(1, 10)")
        print((await cur.fetchone())[0])  # 55

asyncio.run(main())

Synchronization driver

Use a remote Turso database while working locally. You can bootstrap local state from the remote, pull remote changes, and push local commits.

Note: You need a Turso remote URL. See the Turso docs for provisioning and authentication.

import turso.sync

# Connect a local database to a remote Turso database
conn = turso.sync.connect(
    ":memory:",                          # local db path (or a file path)
    remote_url="https://<db>.<region>.turso.io"  # your remote URL
)

# Read data (fetched from remote if not present locally yet)
rows = conn.execute("SELECT * FROM t").fetchall()
print(rows)

# Pull new changes from remote into local
changed = conn.pull()
print("Pulled:", changed)  # True if there were new remote changes

# Make local changes
conn.execute("INSERT INTO t VALUES ('push works')")
conn.commit()

# Push local commits to remote
conn.push()

# Optional: inspect and manage sync state
stats = conn.stats()
print("Network received (bytes):", stats.network_received_bytes)
conn.checkpoint()  # compact local WAL after many writes

conn.close()

Partial bootstrap to reduce initial network cost:

import turso.sync

conn = turso.sync.connect(
    "local.db",
    remote_url="https://<db>.<region>.turso.io",
    # fetch first 128 KiB upfront
    partial_sync_experimental=turso.sync.PartialSyncOpts(
      bootstrap_strategy=turso.sync.PartialSyncPrefixBootstrap(length=128 * 1024),
    ),
)

Synchronization driver (asyncio)

The same sync primitives, but fully async:

import asyncio

async def main():
    conn = await turso.aio.sync.connect(":memory:", remote_url="https://<db>.<region>.turso.io")

    # Read data
    rows = await (await conn.execute("SELECT * FROM t")).fetchall()
    print(rows)

    # Pull and push
    await conn.pull()
    await conn.execute("INSERT INTO t VALUES ('hello from asyncio')")
    await conn.commit()
    await conn.push()

    # Stats and maintenance
    stats = await conn.stats()
    print("Main WAL size:", stats.main_wal_size)
    await conn.checkpoint()

    await conn.close()

asyncio.run(main())

License

This project is licensed under the MIT license.

Support

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

pyturso-0.7.0rc12.tar.gz (2.7 MB view details)

Uploaded Source

Built Distributions

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

pyturso-0.7.0rc12-cp310-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (25.5 MB view details)

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

pyturso-0.7.0rc12-cp310-abi3-manylinux_2_17_aarch64.manylinux2014_aarch64.whl (25.0 MB view details)

Uploaded CPython 3.10+manylinux: glibc 2.17+ ARM64

pyturso-0.7.0rc12-cp310-abi3-macosx_11_0_arm64.whl (7.5 MB view details)

Uploaded CPython 3.10+macOS 11.0+ ARM64

pyturso-0.7.0rc12-cp310-abi3-macosx_10_12_x86_64.whl (8.4 MB view details)

Uploaded CPython 3.10+macOS 10.12+ x86-64

File details

Details for the file pyturso-0.7.0rc12.tar.gz.

File metadata

  • Download URL: pyturso-0.7.0rc12.tar.gz
  • Upload date:
  • Size: 2.7 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: maturin/1.14.1

File hashes

Hashes for pyturso-0.7.0rc12.tar.gz
Algorithm Hash digest
SHA256 968785d73f540021869c14fd0d407b340e82791a6eff6b9ab8fdf2573bbadd27
MD5 6a01dda17c12e580f37fd2d30792bd92
BLAKE2b-256 695201ed3456c0a78e3df7736f067af4e6b5a19172aa4c6e7b341ba6732c85e1

See more details on using hashes here.

File details

Details for the file pyturso-0.7.0rc12-cp310-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for pyturso-0.7.0rc12-cp310-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 420ab6a05d706b20cb1ebd2c1a09b00a432fe4c074db42a6f6043c4380bb9707
MD5 cc15821aa1a1123d5ae33d7cdb68d0b1
BLAKE2b-256 9a335b696ec74235075524bb812955aa44e6f7716f148b1a9877836d115f6f1a

See more details on using hashes here.

File details

Details for the file pyturso-0.7.0rc12-cp310-abi3-manylinux_2_17_aarch64.manylinux2014_aarch64.whl.

File metadata

File hashes

Hashes for pyturso-0.7.0rc12-cp310-abi3-manylinux_2_17_aarch64.manylinux2014_aarch64.whl
Algorithm Hash digest
SHA256 f363923dcf3f38f53e5874224bcf8d06a7b12bea21f4c908510d16ea1d4880fc
MD5 fe57cf61b525e0859e15259311d79e1a
BLAKE2b-256 dd837efbbbeeddb3152a499989ce78f9fc8ec9abe9b24ca18bb0dce6bc43464e

See more details on using hashes here.

File details

Details for the file pyturso-0.7.0rc12-cp310-abi3-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for pyturso-0.7.0rc12-cp310-abi3-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 3d50c156358bf94534f179edb90b33b79cfbe41016eb3d99b847c2a1a7e06f79
MD5 241a37ebb02925bf5800774156522c91
BLAKE2b-256 46f3a59d024bbe49cd10f63866849be191a6db787a651a6fa06a1a7fa132b0e0

See more details on using hashes here.

File details

Details for the file pyturso-0.7.0rc12-cp310-abi3-macosx_10_12_x86_64.whl.

File metadata

File hashes

Hashes for pyturso-0.7.0rc12-cp310-abi3-macosx_10_12_x86_64.whl
Algorithm Hash digest
SHA256 751f350f6aa66ae529e5ea8afcc731e14030b59b9e9d3a2d728e856171ec00d7
MD5 85e79c6c1b2f55274b76dbaf58b24350
BLAKE2b-256 fb0c8e6831ea4135b70bcd537b87c11acb6479f459b7403504d939a56a6647cf

See more details on using hashes here.

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