1 unstable release
0.1.0 | Oct 6, 2024 |
---|
#2411 in Database interfaces
Used in yesqlr_macros
16KB
286 lines
yesqlr
yesqlr is a Rust port of the goyesql Go library.
It allows multiple SQL queries to be defined in an .sql
file, each separate by a specially formatted --name: $name
accompanying every query, which the library then parses to a HashMap<$name, Query{}>.
In addition, it also supports attaching arbitrary --$key: $value tags with every query
This allows better organization and handling of SQL code in Rust projects.
Usage
Create a .sql
file with multiple queries, each preceded by a -- name: query_name
tag. Additional tags can be added as needed.
-- name: get_user
-- raw: true
SELECT * FROM users WHERE id = $1;
-- name: create_user
INSERT INTO users (name, email) VALUES ($1, $2);
Parsing SQL files
Use the parse_file()
function to read and parse the .sql
file.
use yesqlr::parse_file;
fn main() -> Result<(), yesqlr::ParseError> {
let queries = parse_file("test.sql").expect("error parsing file");
let q = &queries["simple"].query;
println!("the query is: {}", q);
Ok(())
}
Parsing bytes / Reader
Alternatively, parse SQL queries from a byte stream using the parse()
function.
use yesqlr::parse;
fn main() -> Result<(), yesqlr::ParseError> {
let raq = b"-- name: list_users\nSELECT * FROM users;";
let queries = parse(&raq[..])?;
let list_users_query = &queries["list_users"].query;
println!("user query is: {}", list_users_query);
Ok(())
}
License
This project is licensed under the MIT License. See the LICENSE file for details.
Dependencies
~2–3MB
~53K SLoC