pub struct PgPool(/* private fields */);Expand description
The shared PostgreSQL connection pool
§Example
use diesel_rocket_pg::PgPool;
use diesel::prelude::*;
use rocket::State;
use serde::Serialize;
#[macro_use] extern crate rocket;
diesel::table! {
user (id) {
id -> Int4,
email -> Varchar,
password -> Varchar,
}
}
#[derive(Debug, Queryable, Serialize)]
pub struct AuthUser {
pub id: i32,
pub email: String,
pub password: String,
}
#[get("/user/<mail>")]
async fn get_user(mail: String, pool: &State<PgPool>) -> String {
let result = pool.run(move |conn| {
user::dsl::user.filter(
user::dsl::email.eq(mail)
).first::<AuthUser>(conn).ok()
}).await.unwrap();
if let Some(u) = result {
format!("{:?}", u)
} else {
"User not found!".to_string()
}
}
#[launch]
fn rocket() -> _ {
let uri = "postgres://user:password123@localhost:5432/database";
let pool = PgPool::create(uri).unwrap();
rocket::build().manage(pool).mount("/", routes![get_user])
}Implementations§
Source§impl PgPool
impl PgPool
Sourcepub fn create_custom<T: Into<String>>(
uri: T,
builder: Builder<ConnectionManager<PgConnection>>,
) -> Result<Self>
pub fn create_custom<T: Into<String>>( uri: T, builder: Builder<ConnectionManager<PgConnection>>, ) -> Result<Self>
Creates a new connection pool with a custom r2d2 configuration
§Arguments
uri- The postgresql connection stringbuilder- Ar2d2::Builderwith a custom configuration
§Example
use diesel_rocket_pg::PgPool;
use r2d2::Pool;
fn main() {
let uri = "postgres://user:password123@localhost:5432/database";
let builder = Pool::builder()
.max_size(50)
.min_idle(None)
.max_lifetime(Some(Duration::from_secs(5)));
let _pool = PgPool::create_custom(uri, builder).unwrap();
/* ... */
}Sourcepub async fn run<F, R>(&self, func: F) -> Result<R>
pub async fn run<F, R>(&self, func: F) -> Result<R>
Executes a diesel query in a tokio task
§Example
#[get("/user/<mail>")]
async fn get_user(mail: String, pool: &State<PgPool>) -> AuthUser {
let auth_user = pool.run(move |conn| {
user::dsl::user.filter(
user::dsl::email.eq(mail)
).first::<AuthUser>(conn).unwrap()
}).await.unwrap();
auth_user
}Trait Implementations§
Auto Trait Implementations§
impl Freeze for PgPool
impl !RefUnwindSafe for PgPool
impl Send for PgPool
impl Sync for PgPool
impl Unpin for PgPool
impl !UnwindSafe for PgPool
Blanket Implementations§
Source§impl<T> AggregateExpressionMethods for T
impl<T> AggregateExpressionMethods for T
Source§fn aggregate_distinct(self) -> Self::Outputwhere
Self: DistinctDsl,
fn aggregate_distinct(self) -> Self::Outputwhere
Self: DistinctDsl,
DISTINCT modifier for aggregate functions Read moreSource§fn aggregate_all(self) -> Self::Outputwhere
Self: AllDsl,
fn aggregate_all(self) -> Self::Outputwhere
Self: AllDsl,
ALL modifier for aggregate functions Read moreSource§fn aggregate_filter<P>(self, f: P) -> Self::Output
fn aggregate_filter<P>(self, f: P) -> Self::Output
Add an aggregate function filter Read more
Source§fn aggregate_order<O>(self, o: O) -> Self::Outputwhere
Self: OrderAggregateDsl<O>,
fn aggregate_order<O>(self, o: O) -> Self::Outputwhere
Self: OrderAggregateDsl<O>,
Add an aggregate function order Read more
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
Source§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Converts
Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>, which can then be
downcast into Box<dyn ConcreteType> where ConcreteType implements Trait.Source§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Converts
Rc<Trait> (where Trait: Downcast) to Rc<Any>, which can then be further
downcast into Rc<ConcreteType> where ConcreteType implements Trait.Source§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
Converts
&Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &Any’s vtable from &Trait’s.Source§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
Converts
&mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &mut Any’s vtable from &mut Trait’s.Source§impl<T> DowncastSend for T
impl<T> DowncastSend for T
Source§impl<T> DowncastSync for T
impl<T> DowncastSync for T
Source§impl<T> IntoSql for T
impl<T> IntoSql for T
Source§fn into_sql<T>(self) -> Self::Expression
fn into_sql<T>(self) -> Self::Expression
Convert
self to an expression for Diesel’s query builder. Read moreSource§fn as_sql<'a, T>(&'a self) -> <&'a Self as AsExpression<T>>::Expression
fn as_sql<'a, T>(&'a self) -> <&'a Self as AsExpression<T>>::Expression
Convert
&self to an expression for Diesel’s query builder. Read moreSource§impl<T> WindowExpressionMethods for T
impl<T> WindowExpressionMethods for T
Source§fn over(self) -> Self::Outputwhere
Self: OverDsl,
fn over(self) -> Self::Outputwhere
Self: OverDsl,
Turn a function call into a window function call Read more
Source§fn window_filter<P>(self, f: P) -> Self::Output
fn window_filter<P>(self, f: P) -> Self::Output
Add a filter to the current window function Read more
Source§fn partition_by<E>(self, expr: E) -> Self::Outputwhere
Self: PartitionByDsl<E>,
fn partition_by<E>(self, expr: E) -> Self::Outputwhere
Self: PartitionByDsl<E>,
Add a partition clause to the current window function Read more
Source§fn window_order<E>(self, expr: E) -> Self::Outputwhere
Self: OrderWindowDsl<E>,
fn window_order<E>(self, expr: E) -> Self::Outputwhere
Self: OrderWindowDsl<E>,
Add a order clause to the current window function Read more