| Crates.io | clorinde |
| lib.rs | clorinde |
| version | 1.1.0 |
| created_at | 2025-01-06 04:07:33.909974+00 |
| updated_at | 2025-08-13 08:06:44.771755+00 |
| description | Generate type-checked Rust from your PostgreSQL queries. |
| homepage | https://github.com/halcyonnouveau/clorinde |
| repository | https://github.com/halcyonnouveau/clorinde |
| max_upload_size | |
| id | 1505289 |
| size | 332,671 |
Clorinde generates type-checked Rust interfaces from PostgreSQL queries, with an emphasis on compile-time safety and high performance. It works by preparing your queries against an actual database and then running an extensive validation suite on them. Rust code is then generated into a separate crate, which can be imported and used in your project.
The basic premise is thus to:
You can learn more about Clorinde by reading the book, or you can get a quickstart by looking at the examples.
[!NOTE] Clorinde is a fork of Cornucopia which enhances the original with an improved architecture and expanded capabilities. Visit the migration guide if you are moving over an existing codebase with Cornucopia.
rust-postgres code.Install with:
cargo install clorinde
Write your PostgreSQL queries with annotations and named parameters:
-- queries/authors.sql
--! insert_author
INSERT INTO authors
(first_name, last_name, country)
VALUES
(:first_name, :last_name, :country);
--! authors
SELECT first_name, last_name, country FROM authors;
Generate the crate with clorinde, then you can import it into your project after adding it to your Cargo.toml:
clorinde = { path = "./clorinde" }
And use the generated crate in your code:
use clorinde::queries::authors::{authors, insert_author};
insert_author.bind(&client, "Agatha", "Christie", "England");
let all_authors = authors().bind(&client).all();
for author in all_authors {
println!("[{}] {}, {}",
author.country,
author.last_name.to_uppercase(),
author.first_name
)
}
For more examples go to the examples directory, or head over to the book to learn more.
This crate uses Rust 2021 edition, which requires at least version 1.62.1.
Licensed under either of
at your option.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.