A pure, safe, no_std-capable Rust re-implementation of SQLite, as a single
crate, aiming for byte-for-byte compatibility with the SQLite 3 database file
format.
Status: read + write working, with a broad SQL engine. graphitesql opens real SQLite files and creates databases that the real
sqlite3CLI opens withPRAGMA integrity_check = ok. Storage covers rowid andWITHOUT ROWIDtables, secondary/UNIQUE/partial/expression indexes, overflow pages,VACUUM, the fullauto_vacuumtrack, and the WAL read and write path. The SQL surface coversINNER/LEFT/RIGHT/FULL/NATURAL/USINGjoins, aggregates,GROUP BY/HAVING, compound queries, (recursive) CTEs, correlated subqueries &EXISTS, window functions, UPSERT,RETURNING,STRICTtables, generated columns, triggers, foreign keys, ATTACH / TEMP multi-schema, virtual tables (built-inseries,rtree, andfts5modules — full-textMATCHwith phrases, prefixes, column filters,AND/OR/NOT,NEAR,^anchors,bm25()/rankrelevance ordering, andhighlight()— plusregister_module/register_functionfor your own), and a wide function library — date/time,printf, math, JSON + JSONB, and more — with an index-driven planner andEXPLAIN QUERY PLANmatching sqlite. Everything is verified differentially againstsqlite3(a 1,600+ query corpus plus 140+ focused suites). What remains is depth: the FTS5 / R-Tree on-disk index formats, R-Tree spatial pushdown, the executor→VDBE migration, and concurrency — see the full plan in ROADMAP.md.
SQLite is the most-deployed database in the world, but it's C. graphitesql brings
the same file format and SQL dialect to places where a safe, dependency-free,
no_std Rust library shines:
- WebAssembly — run a real SQLite-compatible database in the browser or in a wasm sandbox with no JS shim and no Emscripten.
- Embedded / bare-metal —
no_std+alloc, bring-your-own storage. - Sandboxed / capability-based hosts — no
unsafe, no FFI, no syscalls except through aVfstrait you control.
- ✅ File-format compatible. Open a database written by
sqlite3; write onesqlite3can open. Verified with differential tests against the C library. - ✅ Safe.
#![forbid(unsafe_code)]across the whole crate. - ✅ Portable.
#![no_std]+alloc. Optionalstdfeature for real files. - ✅ Single crate. Storage, B-tree, SQL parser, and VM all live in
graphitesql. - ✅ No dependencies. Only
coreandalloc.
- Being a faster SQLite. Correctness and compatibility first.
- 100% of every SQLite extension (FTS5, R-Tree, sessions, …). These are layered in later, behind features. See the roadmap.
- Drop-in C ABI (
libsqlite3.so). A C-API shim is a possible future crate, not the core.
Create a database, write to it, and read it back — and sqlite3 can open it too:
use graphitesql::{Connection, Value};
let mut db = Connection::open_memory()?; // or Connection::create("app.db")?
db.execute("CREATE TABLE users(id INTEGER PRIMARY KEY, name TEXT)")?;
db.execute("INSERT INTO users(name) VALUES ('ada'), ('grace')")?;
db.execute("UPDATE users SET name = 'Ada Lovelace' WHERE id = 1")?;
let result = db.query("SELECT id, name FROM users ORDER BY name")?;
for row in &result.rows {
if let (Value::Integer(id), Value::Text(name)) = (&row[0], &row[1]) {
println!("{id}: {name}");
}
}
// Aggregates, GROUP BY, joins, expressions, scalar functions, transactions:
db.query("SELECT u.name, sum(o.amount) FROM users u JOIN orders o \
ON u.id = o.user_id GROUP BY u.name")?;
db.execute("BEGIN")?;
db.execute("DELETE FROM users WHERE id = 2")?;
db.execute("COMMIT")?;Open an existing sqlite3-written file with Connection::open("file.db") (or
open_readonly). Low-level format primitives are public too
(graphitesql::format::DatabaseHeader, graphitesql::btree, …).
The crate ships a graphitesql binary modeled on the sqlite3 CLI:
cargo run --bin graphitesql # in-memory, interactive
cargo run --bin graphitesql -- app.db # open/create app.db, interactive
cargo run --bin graphitesql -- app.db "SELECT * FROM users;" # one-shotIt accepts ;-terminated SQL (multi-line) and dot-commands: .tables,
.schema [table], .headers on|off, .help, .quit. Results print in
SQLite's default |-separated list mode.
| feature | default | effect |
|---|---|---|
std |
on | std-file Vfs, std::error::Error impl |
fts5 |
on | built-in FTS5 full-text search (MATCH, bm25()/rank, highlight()) |
Disable default features for no_std. An in-memory VFS (:memory:) is always
available, including on wasm. Drop fts5 (e.g. --no-default-features --features std) to build without full-text search.
cargo test # full suite (std)
cargo build --no-default-features # no_std build
cargo clippy --all-targets # lints (unsafe is forbidden)graphitesql is an independent re-implementation. It uses SQLite's public-domain source and documentation purely as a specification reference — no SQLite code is compiled into this crate. Fetch the (git-ignored, hash-verified) reference tree with:
./reference/fetch.shDeep gratitude to D. Richard Hipp and the SQLite developers. See
NOTICE and ATTRIBUTION.md.
Public domain, mirroring SQLite. In place of a legal notice, graphitesql
carries a blessing — see LICENSE. The SPDX identifier is
blessing (the SQLite Blessing).