2014-11-04 11:32:06 -05:00
|
|
|
# Rusqlite
|
|
|
|
|
2016-02-01 14:19:51 -05:00
|
|
|
[![Travis Build Status](https://api.travis-ci.org/jgallagher/rusqlite.svg?branch=master)](https://travis-ci.org/jgallagher/rusqlite)
|
|
|
|
[![AppVeyor Build Status](https://ci.appveyor.com/api/projects/status/github/jgallagher/rusqlite?branch=master&svg=true)](https://ci.appveyor.com/project/jgallagher/rusqlite)
|
2014-11-04 12:48:33 -05:00
|
|
|
|
2014-11-10 12:56:32 -05:00
|
|
|
Rusqlite is an ergonomic wrapper for using SQLite from Rust. It attempts to expose
|
2014-11-04 15:36:04 -05:00
|
|
|
an interface similar to [rust-postgres](https://github.com/sfackler/rust-postgres). View the full
|
2015-05-03 21:50:09 -04:00
|
|
|
[API documentation](http://jgallagher.github.io/rusqlite/rusqlite/index.html).
|
2014-11-04 11:32:06 -05:00
|
|
|
|
|
|
|
```rust
|
|
|
|
extern crate rusqlite;
|
|
|
|
extern crate time;
|
|
|
|
|
|
|
|
use time::Timespec;
|
2015-12-12 13:50:12 -05:00
|
|
|
use rusqlite::Connection;
|
2014-11-04 11:32:06 -05:00
|
|
|
|
2015-02-03 18:59:58 -05:00
|
|
|
#[derive(Debug)]
|
2014-11-04 11:32:06 -05:00
|
|
|
struct Person {
|
|
|
|
id: i32,
|
|
|
|
name: String,
|
|
|
|
time_created: Timespec,
|
|
|
|
data: Option<Vec<u8>>
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {
|
2015-12-12 13:50:12 -05:00
|
|
|
let conn = Connection::open_in_memory().unwrap();
|
2014-11-04 11:32:06 -05:00
|
|
|
|
|
|
|
conn.execute("CREATE TABLE person (
|
|
|
|
id INTEGER PRIMARY KEY,
|
|
|
|
name TEXT NOT NULL,
|
|
|
|
time_created TEXT NOT NULL,
|
|
|
|
data BLOB
|
2014-12-03 17:14:49 +01:00
|
|
|
)", &[]).unwrap();
|
2014-11-04 11:32:06 -05:00
|
|
|
let me = Person {
|
|
|
|
id: 0,
|
|
|
|
name: "Steven".to_string(),
|
|
|
|
time_created: time::get_time(),
|
|
|
|
data: None
|
|
|
|
};
|
|
|
|
conn.execute("INSERT INTO person (name, time_created, data)
|
|
|
|
VALUES ($1, $2, $3)",
|
|
|
|
&[&me.name, &me.time_created, &me.data]).unwrap();
|
|
|
|
|
|
|
|
let mut stmt = conn.prepare("SELECT id, name, time_created, data FROM person").unwrap();
|
2015-05-07 15:36:29 +02:00
|
|
|
let mut person_iter = stmt.query_map(&[], |row| {
|
|
|
|
Person {
|
2014-11-04 11:32:06 -05:00
|
|
|
id: row.get(0),
|
|
|
|
name: row.get(1),
|
|
|
|
time_created: row.get(2),
|
|
|
|
data: row.get(3)
|
2015-05-07 15:36:29 +02:00
|
|
|
}
|
|
|
|
}).unwrap();
|
|
|
|
|
|
|
|
for person in person_iter {
|
|
|
|
println!("Found person {:?}", person.unwrap());
|
2014-11-04 11:32:06 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2015-12-12 16:04:11 -05:00
|
|
|
### Optional Features
|
|
|
|
|
|
|
|
Rusqlite provides several features that are behind [Cargo
|
|
|
|
features](http://doc.crates.io/manifest.html#the-features-section). They are:
|
|
|
|
|
|
|
|
* [`load_extension`](http://jgallagher.github.io/rusqlite/rusqlite/struct.LoadExtensionGuard.html)
|
|
|
|
allows loading dynamic library-based SQLite extensions.
|
|
|
|
* [`backup`](http://jgallagher.github.io/rusqlite/rusqlite/backup/index.html)
|
|
|
|
allows use of SQLite's online backup API.
|
|
|
|
* [`functions`](http://jgallagher.github.io/rusqlite/rusqlite/functions/index.html)
|
|
|
|
allows you to load Rust closures into SQLite connections for use in queries.
|
|
|
|
* [`trace`](http://jgallagher.github.io/rusqlite/rusqlite/trace/index.html)
|
|
|
|
allows hooks into SQLite's tracing and profiling APIs.
|
2015-12-14 16:24:11 -05:00
|
|
|
* [`blob`](http://jgallagher.github.io/rusqlite/rusqlite/blob/index.html)
|
|
|
|
gives `std::io::{Read, Write, Seek}` access to SQL BLOBs.
|
2015-12-12 16:04:11 -05:00
|
|
|
|
2014-11-04 11:32:06 -05:00
|
|
|
## Author
|
|
|
|
|
|
|
|
John Gallagher, johnkgallagher@gmail.com
|
|
|
|
|
|
|
|
## License
|
|
|
|
|
|
|
|
Rusqlite is available under the MIT license. See the LICENSE file for more info.
|