| Crates.io | versatile-dataloader |
| lib.rs | versatile-dataloader |
| version | 0.1.1 |
| created_at | 2025-05-18 13:49:43.982253+00 |
| updated_at | 2025-06-15 16:31:39.876528+00 |
| description | An async data loader for Rust. |
| homepage | |
| repository | https://github.com/worldofjoni/versatile-dataloader |
| max_upload_size | |
| id | 1678656 |
| size | 57,131 |
A dataloader (originally developed by facebook) allows to batch requests coming in at roughly the same time. This is useful e.g., to avoid the n+1 problem in GraphQL.
Forked/extracted from async-graphql as it has no dependencies towards async-graphql and might be useful on its own.
use std::collections::{HashSet, HashMap};
use std::convert::Infallible;
use versatile_dataloader::{Loader, DataLoader};
/// This loader simply converts the integer key into a string value.
struct MyLoader;
impl Loader<i32, String> for MyLoader {
type Error = Infallible;
async fn load(&self, keys: &[i32]) -> Result<HashMap<i32, String>, Self::Error> {
// Implement database access or similar here.
Ok(keys.iter().copied().map(|n| (n, n.to_string())).collect())
}
}
tokio::runtime::Builder::new_current_thread().build().unwrap().block_on(async {
// Load data with dataloader:
let loader = DataLoader::new(MyLoader, tokio::spawn);
let strings = vec![loader.load_one(1).await.unwrap(), loader.load_one(2).await.unwrap(), loader.load_one(3).await.unwrap()];
// The dataloader load function is only called once.
assert_eq!(strings, vec![Some("1".to_string()), Some("2".to_string()), Some("3".to_string())]);
});
Licensed under either of