Crates.io | libdb |
lib.rs | libdb |
version | 0.1.1 |
source | src |
created_at | 2020-03-11 21:33:14.531746 |
updated_at | 2020-03-12 22:06:06.442477 |
description | statically linked rust bindings for Berkeley DB |
homepage | |
repository | https://github.com/fishi0x01/libdb-rs |
max_upload_size | |
id | 217676 |
size | 50,431 |
Status
Statically linked rust bindings for Berkeley DB.
This is a humble fork from jesterpm's libdb-rs.
v4_8
uses bindings for Berkeley DB 4.8.x.
v5_3
uses bindings for Berkeley DB 5.3.x.
By default, Berkeley DB 5.3.x is used.
extern crate libdb;
let env = libdb::EnvironmentBuilder::new()
.flags(libdb::DB_CREATE | libdb::DB_RECOVER | libdb::DB_INIT_TXN | libdb::DB_INIT_MPOOL)
.open()
.unwrap();
let txn = env.txn(None, libdb::DB_NONE).unwrap();
let db = libdb::DatabaseBuilder::new()
.environment(&env)
.transaction(&txn)
.db_type(libdb::DbType::BTree)
.flags(libdb::DB_CREATE)
.open()
.unwrap();
txn.commit(libdb::CommitType::Inherit).expect("Commit failed!");
let mut key = String::from("key").into_bytes();
let mut value = String::from("value").into_bytes();
db.put(None, key.as_mut_slice(), value.as_mut_slice(), libdb::DB_NONE).expect("Put failed!");
let result = db.get(None, key.as_mut_slice(), libdb::DB_NONE).unwrap();
println!("{:?}", result);
This crate has its author's crev review.
It is recommended to always use cargo-crev to verify the trustworthiness of each of your dependencies, including this one.
Website: http://www.oracle.com/database/berkeley-db/
License: Sleepycat
Description:
The Berkeley Database (Berkeley DB) is a programmatic toolkit that
provides embedded database support for both traditional and
client/server applications. The Berkeley DB includes B+tree, Extended
Linear Hashing, Fixed and Variable-length record access methods,
transactions, locking, logging, shared memory caching, and database
recovery. The Berkeley DB supports C, C++, Java, and Perl APIs. It is
used by many applications, including Python and Perl, so this should
be installed on all systems.