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)?;
浏览 15
点赞
评论
收藏
分享

手机扫一扫分享

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

手机扫一扫分享

编辑 分享
举报