Popularity
2.5
Declining
Activity
0.0
Stable
58
6
21

Programming language: Rust
License: MIT License
Tags: Database     SQL     Sqlite    

rust-sqlite3 alternatives and similar packages

Based on the "Sqlite" category.
Alternatively, view rust-sqlite3 alternatives based on common mentions on social networks and blogs.

Do you think we are missing an alternative of rust-sqlite3 or a related project?

Add another 'Sqlite' Package

README

Rust-Sqlite3

Rustic bindings for sqlite3. OBSOLETE in favor of jgallagher/rusqlite

Copyright (c) 2014-2017 Dan Connolly and contributors

Share and enjoy. LICENSE: MIT.

Documentation, Status

View the documentation online

Three layers of API are provided:

  • mod ffi provides exhaustive, though unsafe, bindgen bindings for libsqlite.h
  • mod core provides a minimal safe interface to the basic sqlite3 API
  • mod types provides ToSql/FromSql traits, and the library provides convenient query() and update() APIs.

The API design is perhaps stabilizing, though testing is uneven and I have not used the library beyond trivial integration tests.

Build Status

TODO

  • another thorough read-through of the sqlite API intro, with unit tests to match; especially...
    • unit testing other than the happy-paths
  • ToSql/FromSql can now be implemented by clients, but the types module probably doesn't hit the 80% mark yet; e.g. it's missing uint and &[u8].
  • investigate test coverage tools for rust
  • basic benchmarking

Motivation and Acknowledgements

I was looking into sandstorm, a personal cloud platform with an architecture based on the wonderful capability security paradigm, and I found a rust application, acronymy, that uses the native API rather than the traditional POSIX environment.

I started poring over the code and followed the dependency link to linuxfood's rustsqlite. I started working on a memory safety issue etc. but soon found a number of large-scale API design issues that I wasn't sure how to approach with the upstream developers. I was also inspired by FromSql, ToSql and such from sfackler's rust-postgres API.

So I started from scratch, using bindgen, Result (sum types) etc.


*Note that all licence references and agreements mentioned in the rust-sqlite3 README section above are relevant to that project's source code only.