GlueSQL is a SQL database library written in Rust which provides parser (sqlparser-rs), execution layer, and an optional storage (sled).
Developers can use GlueSQL to build their own SQL databases or they can simply use GlueSQL as an embedded SQL database using default storage.
You can simply use GlueSQL as an embedded SQL database, GlueSQL provides sled as a default storage engine.
In your Cargo.toml
[dependencies]
gluesql = { version = "0.1.15", features = ["sled-storage"] }
use gluesql::{parse, Glue, SledStorage};
fn main() {
let storage = SledStorage::new("data.db").unwrap();
let mut glue = Glue::new(storage);
let sqls = "
CREATE TABLE Glue (id INTEGER);
INSERT INTO Glue VALUES (100);
INSERT INTO Glue VALUES (200);
SELECT * FROM Glue WHERE id > 100;
DROP TABLE Glue;
";
for query in parse(sqls).unwrap() {
glue.execute(&query).unwrap();
}
}
Now you don't need to include sled-storage
. So in Cargo.toml
,
[dependencies]
gluesql = "0.1.15"
All you only need to do is implementing 2 traits: Store
and StoreMut
!
In src/store.rs
,
pub trait Store<T: Debug> {
fn fetch_schema(&self, table_name: &str) -> Result<Schema>;
fn scan_data(&self, table_name: &str) -> Result<RowIter<T>>;
}
pub trait StoreMut<T: Debug> where Self: Sized {
fn generate_id(self, table_name: &str) -> MutResult<Self, T>;
fn insert_schema(self, schema: &Schema) -> MutResult<Self, ()>;
fn delete_schema(self, table_name: &str) -> MutResult<Self, ()>;
fn insert_data(self, key: &T, row: Row) -> MutResult<Self, Row>;
fn delete_data(self, key: &T) -> MutResult<Self, ()>;
}
Examples - GlueSQL-js
Use SQL in web browsers!
GlueSQL-js provides 3 storage options,
- in-memory
- localStorage
- sessionStorage.
GlueSQL currently supports limited queries, it's in very early stage.
CREATE
with 4 types:INTEGER
,FLOAT
,BOOLEAN
,TEXT
with an optionalNULL
attribute.INSERT
,UPDATE
,DELETE
,SELECT
,DROP TABLE
- Nested select, join, aggregations ...
You can see current query supports in src/tests/*.
- Run SQL in web browsers - gluesql-js
It would be cool to make state management library using
gluesql-js
. - Add SQL layer to NoSQL databases: Redis, CouchDB...
- Build new SQL database management system
It's very early stage, please feel free to do whatever you want to.
Only the thing you need to be aware of is...
- Except for
src/glue.rs
andsrc/tests/
, there is no place to usemut
keyword.