rusqlite
rfcs
Our great sponsors
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.
rusqlite
-
SQLite + Rust: Building a CLI Password Vault 🦀
"Rusqlite is an ergonomic wrapper for using SQLite from Rust." - Crates.io
-
Rusty way to store state for CLIs
If you're less concerned about the "structure" of your data (e.g., serializing into rust types) and just need tabular data that can be queried (e.g., how much did we bet on X date, who placed a bet on Y team, etc.) I would definitely lean more towards a SQLite database for that kind of work. rusqlite can get you a functional database fairly quickly with a little reading of the documentation (be sure to use the "bundled" feature).
- WASM SQL database recommendations wanted
-
SQLite Release 3.42.0
Create a connection per task. WAL is probably a good idea.
Even using SERIALIZED mode, sqlite has multiple APIs which are completely broken if two clients touch the same connection (https://github.com/rusqlite/rusqlite/issues/342#issuecomment...).
Don't bother, just don't share connections between threads and use the regular multi-thread mode (do use that though).
-
Best way to ship non-code files in a rust crate?
It fails your "ship with a crate" requirement, but when it comes to "csv but too small for a database" it's always worth having a think about SQLite. Of note, the rusqlite crate with the bundled feature will download, compile, and link against sqlite.
-
What does crate rusqlite add over crate sqlite?
You may want to read the Readme of Rusqlite, especially the Optional Features.
-
Embedded SQL database
As far as I know, the only option for an embedded SQL database is SQLite. The most actively maintained one, for rust, seems to be rusqlite (https://github.com/rusqlite/rusqlite).
-
SQLite extension to query Excel (.xlsx, .xls, .ods) files as virtual tables
Yes, but it's readonly. Also they did not merge loadable extensions support, which I need - https://github.com/rusqlite/rusqlite/pull/910
-
Rust for competitive programming
rusqlite 0.27.0, which looks like it's still the latest version
-
Store SQLite in Cloudflare Durable Objects
SQLite is written in C, while workers is based on V8 isolates, so it mainly runs JavaScript. Fortunately, it also supports running WASM through initialising and calling WASM modules via JavaScript. Emscripten can be used to build WASM from C, but I'd rather use it through Rust (using rusqlite), so this is what I focus on right away. Workers can also be written entirely in Rust using worker-rs.
rfcs
-
Have I found a bug? I'm 90% sure the std does exactly this in a lot of places.
See https://github.com/rust-lang/rust/issues/20400 and https://github.com/withoutboats/rfcs/blob/disjoint_associated_types/0000-disjoint_associated_types.md
-
Hey Rustaceans! Got an easy question? Ask here (10/2021)!
I'm not qualified to give an in-depth answer, but the short answer is that you can't. This has been proposed and postponed: Link
What are some alternatives?
SQLite - Interface to SQLite
book - The Rust Programming Language
rust-sqlite3 - Rustic bindings for sqlite3
cross - “Zero setup” cross compilation and “cross testing” of Rust crates
wasm-sqlite - [Experimental] SQLite compiled to WASM with pluggable page storage.
coreutils - Cross-platform Rust rewrite of the GNU coreutils
r2d2 - A generic connection pool for Rust
opencv-rust - Rust bindings for OpenCV 3 & 4
rustsqlite
rust - Empowering everyone to build reliable and efficient software.
case-studies - Analysis of various tricky Rust code