sqlite-zstd用 Rust 编写的 SQLite 压缩扩展

联合创作 · 2023-09-30 21:05

sqlite-zstd 是 SQLite 的扩展,为 SQLite 提供透明的基于字典的行级压缩。这允许你压缩 SQLite 数据库中的条目,就像你压缩整个数据库文件一样,但同时保留了随机访问。



根据不同的数据,这可以将数据库的大小减少 80%,同时保持大部分的性能不变(甚至可以提高性能,因为从磁盘上读取的数据更小)。


编译


该项目可以以两种模式构建:



  • 作为 Rust 库

  • 作为纯 SQLite 扩展


可以从 GitHub release 中获取 SQLite 扩展二进制文件,或者可以手动构建扩展:



cargo build --release --features build_extension
# should give you target/release/libsqlite_zstd.so

用法


可以将此库作为 SQLite 扩展或作为 Rust 库加载。 请注意,sqlite 扩展不是持久的,因此每次连接数据库时都需要加载它。


Sqlite CLI


在 REPL 中加载它:



$ sqlite3 file.db
SQLite version 3.34.0 2020-12-01 16:14:00
sqlite> .load .../libsqlite_zstd.so
[2020-12-23T21:30:02Z INFO sqlite_zstd::create_extension] [sqlite-zstd] initialized
sqlite>

或者:


sqlite3 -cmd '.load libsqlite_zstd.so' 'select * from foo'


C API



int success = sqlite3_load_extension(db, "libsqlite_zstd.so", NULL, NULL);

Rust


推荐的方法是添加 sqlite_zstd作为项目的依赖项,然后使用



let conn: rusqlite::Connection;
sqlite_zstd::load(&conn)?;

或者,也可以像任何其他扩展一样加载扩展:



let conn: rusqlite::Connection;
conn.load_extension("libsqlite_zstd.so", None)?;
浏览 41
点赞
评论
收藏
分享

手机扫一扫分享

编辑 分享
举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

编辑 分享
举报