Skip to main content

SQLite-compatible database with CJK FTS5 support

Project description

sql5

SQLite-compatible database with native CJK FTS5 support. Built with Rust.

v3.0 - Client-Server Architecture with WebSocket Support

sql5 v3.0 consists of:

  • Python package (sql5 on PyPI): Pure Python client
  • Rust binary: Server process providing all SQL functionality

The Python client communicates with the Rust server via:

  • Subprocess mode (default): JSON over stdin/stdout
  • WebSocket mode (v3.0): WebSocket protocol for multi-client support

Installation

pip install sql5

Python API

import sql5

# Subprocess mode (default, v2.0 compatible)
db = sql5.connect("mydb.db")

# Or use WebSocket mode (v3.0, multi-client support)
db = sql5.connect(
    path="mydb.db",
    transport="websocket",
    host="127.0.0.1",
    port=8080
)

# Execute SQL
db.execute("CREATE TABLE users (id INTEGER PRIMARY KEY, name TEXT, age INTEGER)")
db.execute("INSERT INTO users VALUES (1, 'Alice', 30)")
db.execute("INSERT INTO users VALUES (2, 'Bob', 25)")
db.execute("INSERT INTO users VALUES (3, 'Charlie', 35)")

# Query with parameters
db.execute("INSERT INTO users VALUES (?, ?, ?)", (4, "David", 28))

# Fetch results
cursor = db.execute("SELECT * FROM users WHERE age > ?", (25,))
for row in cursor:
    print(row)
# (1, 'Alice', 30)
# (2, 'Bob', 25)
# (3, 'Charlie', 35)
# (4, 'David', 28)

# Fetch as list
cursor = db.execute("SELECT name, age FROM users ORDER BY age")
rows = cursor.fetchall()
print(rows)
# [('Bob', 25), ('David', 28), ('Alice', 30), ('Charlie', 35)]

# Fetch one
cursor = db.execute("SELECT * FROM users WHERE id = ?", (1,))
row = cursor.fetchone()
print(row)
# (1, 'Alice', 30)

# Transactions
db.execute("BEGIN")
db.execute("INSERT INTO users VALUES (5, 'Eve', 40)")
db.execute("COMMIT")

# Or rollback
db.execute("BEGIN")
db.execute("INSERT INTO users VALUES (6, 'Frank', 45)")
db.execute("ROLLBACK")

# Full-text search (FTS5)
db.execute("CREATE VIRTUAL TABLE articles USING fts5(title, body)")
db.execute("INSERT INTO articles VALUES ('Hello World', 'The quick brown fox')")
db.execute("INSERT INTO articles VALUES ('Rust Guide', 'Memory safety without GC')")
db.execute("INSERT INTO articles VALUES ('中文測試', '繁體中文全文檢索')")

cursor = db.execute("SELECT * FROM articles WHERE articles MATCH ?", ("rust",))
print(cursor.fetchall())
# [('Rust Guide', 'Memory safety without GC')]

cursor = db.execute("SELECT * FROM articles WHERE articles MATCH ?", ("中文",))
print(cursor.fetchall())
# [('中文測試', '繁體中文全文檢索')]

# Close database
db.close()

Connection Parameters

Parameter Type Default Description
path str None Database file path
transport str "subprocess" "subprocess" or "websocket"
host str "127.0.0.1" WebSocket server host
port int 8080 WebSocket server port

CLI Usage

# Run the REPL
sql5

# Open a database file
sql5 /path/to/database.db

# Execute single query
echo "SELECT 1 + 1;" | sql5

Features

  • Full SQL support (SELECT, INSERT, UPDATE, DELETE, CREATE, DROP)
  • ACID transactions (BEGIN, COMMIT, ROLLBACK)
  • WAL mode
  • Foreign keys
  • Views
  • Triggers
  • Full-text search (FTS5) with CJK bigram tokenization
  • Multiple database attachment (ATTACH DATABASE)
  • Window functions (ROW_NUMBER, RANK, LAG, LEAD, etc.)
  • String functions (UPPER, LOWER, SUBSTR, REPLACE, etc.)
  • Date/time functions (DATE, TIME, DATETIME, STRFTIME)
  • JSON functions (JSON, JSON_EXTRACT, JSON_SET, etc.)
  • WebSocket server mode (v3.0, multi-client support)
  • Subprocess server mode (v2.0, backward compatible)

Requirements

  • Python 3.8+
  • For WebSocket mode: pip install websocket-client (auto-installed as dependency)

Development

To use a local Rust binary instead of downloading from GitHub:

export SQL5_BINARY=/path/to/local/sql5
python -c "import sql5; print(sql5.__version__)"

License

MIT

Project details


Download files

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

Source Distribution

sql5-3.2.12.tar.gz (14.3 kB view details)

Uploaded Source

Built Distribution

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

sql5-3.2.12-py3-none-any.whl (10.0 kB view details)

Uploaded Python 3

File details

Details for the file sql5-3.2.12.tar.gz.

File metadata

  • Download URL: sql5-3.2.12.tar.gz
  • Upload date:
  • Size: 14.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.9

File hashes

Hashes for sql5-3.2.12.tar.gz
Algorithm Hash digest
SHA256 c1f946f45b2c374d4311140aaee681e1573abb68c76cde955a9454827a14d98f
MD5 7f5fd19178ff39247b75cc7eeeda91a9
BLAKE2b-256 24788768c95db3e6550e9adc24c6179bcc3cce94c680ea1788e03ef4d126bb5b

See more details on using hashes here.

File details

Details for the file sql5-3.2.12-py3-none-any.whl.

File metadata

  • Download URL: sql5-3.2.12-py3-none-any.whl
  • Upload date:
  • Size: 10.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.9

File hashes

Hashes for sql5-3.2.12-py3-none-any.whl
Algorithm Hash digest
SHA256 7b1370bc0ba50ded737f05f6ae66f2783e575dc4fc6dff387edf6d0e672e5b42
MD5 528629ab8532c2544a5cdc67819aea3d
BLAKE2b-256 3f90d1e432d8ee52e0f93fbb414e716cb2f29d8f4478825f1058a7a31c18bf8e

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