20 releases

0.0.10 Dec 28, 2024
0.0.8 Dec 8, 2024
0.0.6 Nov 12, 2024
0.0.3 Aug 17, 2024
0.0.1-alpha.9 Jan 28, 2024

#310 in Database interfaces

Download history 8/week @ 2024-09-18 5/week @ 2024-09-25 2/week @ 2024-10-02 107/week @ 2024-10-30 194/week @ 2024-11-06 85/week @ 2024-11-13 11/week @ 2024-11-20 220/week @ 2024-12-04 73/week @ 2024-12-11 35/week @ 2024-12-18 169/week @ 2024-12-25 37/week @ 2025-01-01

347 downloads per month

Apache-2.0

2MB
30K SLoC

Built by @KipData


███████╗███╗   ██╗ ██████╗██╗  ██╗    ███████╗ ██████╗ ██╗     
██╔════╝████╗  ██║██╔════╝██║ ██╔╝    ██╔════╝██╔═══██╗██║     
█████╗  ██╔██╗ ██║██║     █████╔╝     ███████╗██║   ██║██║     
██╔══╝  ██║╚██╗██║██║     ██╔═██╗     ╚════██║██║▄▄ ██║██║     
██║     ██║ ╚████║╚██████╗██║  ██╗    ███████║╚██████╔╝███████╗
╚═╝     ╚═╝  ╚═══╝ ╚═════╝╚═╝  ╚═╝    ╚══════╝ ╚══▀▀═╝ ╚══════╝

-----------------------------------
🖕

SQL as a Function for Rust

 

CI github star github fork

Introduction

FnckSQL is a lightweight embedded database inspired by MyRocks and SQLite and completely coded in Rust. It aims to provide a more user-friendly, lightweight, and low-loss RDBMS for Rust programming so that the APP does not rely on other complex components. can perform complex relational data operations

Key Features

  • A lightweight embedded SQL database fully rewritten in Rust
  • Higher write speed, more user-friendly API
  • All metadata and actual data in KV Storage, and there is no state component (e.g. system table) in the middle
  • Supports extending storage for customized workloads
  • Supports most of the SQL 2016 syntax

👉check more

Examples

let fnck_sql = DataBaseBuilder::path("./data").build()?;

fnck_sql
    .run("create table if not exists t1 (c1 int primary key, c2 int)")?
    .done()?;
fnck_sql
    .run("insert into t1 values(0, 0), (1, 1)")?
    .done()?;

for tuple in fnck_sql.run("select * from t1")? {
    println!("{:?}", tuple?);
}

👉more examples

TPC-C

run cargo run -p tpcc --release to run tpcc

  • i9-13900HX
  • 32.0 GB
  • KIOXIA-EXCERIA PLUS G3 SSD
  • Tips: TPC-C currently only supports single thread
<90th Percentile RT (MaxRT)>
   New-Order : 0.002  (0.004)
     Payment : 0.001  (0.025)
Order-Status : 0.053  (0.175)
    Delivery : 0.022  (0.027)
 Stock-Level : 0.003  (0.019)
<TpmC>
7815 tpmC

👉check more

Roadmap

License

FnckSQL uses the Apache 2.0 license to strike a balance between open contributions and allowing you to use the software however you want.

Contributors

Dependencies

~37–52MB
~1M SLoC