pub struct WithStats<T>(pub T);
Expand description
Responses returned with statistics
Tuple Fields§
§0: T
Implementations§
Source§impl WithStats<Response>
impl WithStats<Response>
Sourcepub fn take<R>(
&mut self,
index: impl QueryResult<R>,
) -> Option<(Stats, Result<R>)>where
R: DeserializeOwned,
pub fn take<R>(
&mut self,
index: impl QueryResult<R>,
) -> Option<(Stats, Result<R>)>where
R: DeserializeOwned,
Takes and returns records returned from the database
Similar to Response::take but this method returns None
when
you try taking an index that doesn’t correspond to a query
statement.
§Examples
use serde::Deserialize;
use surrealdb::RecordId;
#[derive(Debug, Deserialize)]
struct User {
id: RecordId,
balance: String
}
let mut response = db
// Get `john`'s details
.query("SELECT * FROM user:john")
// List all users whose first name is John
.query("SELECT * FROM user WHERE name.first = 'John'")
// Get John's address
.query("SELECT address FROM user:john")
// Get all users' addresses
.query("SELECT address FROM user")
// Return stats along with query results
.with_stats()
.await?;
// Get the first (and only) user from the first query
if let Some((stats, result)) = response.take(0) {
let execution_time = stats.execution_time;
let user: Option<User> = result?;
}
// Get all users from the second query
if let Some((stats, result)) = response.take(1) {
let execution_time = stats.execution_time;
let users: Vec<User> = result?;
}
// Retrieve John's address without making a special struct for it
if let Some((stats, result)) = response.take((2, "address")) {
let execution_time = stats.execution_time;
let address: Option<String> = result?;
}
// Get all users' addresses
if let Some((stats, result)) = response.take((3, "address")) {
let execution_time = stats.execution_time;
let addresses: Vec<String> = result?;
}
Sourcepub fn take_errors(&mut self) -> HashMap<usize, (Stats, Error)>
pub fn take_errors(&mut self) -> HashMap<usize, (Stats, Error)>
Take all errors from the query response
The errors are keyed by the corresponding index of the statement that failed. Afterwards the response is left with only statements that did not produce any errors.
§Examples
let errors = response.take_errors();
Sourcepub fn check(self) -> Result<Self>
pub fn check(self) -> Result<Self>
Check query response for errors and return the first error, if any, or the response
§Examples
response.check()?;
Sourcepub fn num_statements(&self) -> usize
pub fn num_statements(&self) -> usize
Returns the number of statements in the query
§Examples
let response = db.query("SELECT * FROM user:john; SELECT * FROM user;").await?;
assert_eq!(response.num_statements(), 2);
Sourcepub fn into_inner(self) -> Response
pub fn into_inner(self) -> Response
Returns the unwrapped response
Trait Implementations§
Source§impl<'r, Client> IntoFuture for WithStats<Query<'r, Client>>where
Client: Connection,
impl<'r, Client> IntoFuture for WithStats<Query<'r, Client>>where
Client: Connection,
Source§type Output = Result<WithStats<Response>, Error>
type Output = Result<WithStats<Response>, Error>
The output that the future will produce on completion.
Source§type IntoFuture = Pin<Box<dyn Future<Output = <WithStats<Query<'r, Client>> as IntoFuture>::Output> + Sync + Send + 'r>>
type IntoFuture = Pin<Box<dyn Future<Output = <WithStats<Query<'r, Client>> as IntoFuture>::Output> + Sync + Send + 'r>>
Which kind of future are we turning this into?
Source§fn into_future(self) -> Self::IntoFuture
fn into_future(self) -> Self::IntoFuture
Creates a future from a value. Read more
Auto Trait Implementations§
impl<T> Freeze for WithStats<T>where
T: Freeze,
impl<T> RefUnwindSafe for WithStats<T>where
T: RefUnwindSafe,
impl<T> Send for WithStats<T>where
T: Send,
impl<T> Sync for WithStats<T>where
T: Sync,
impl<T> Unpin for WithStats<T>where
T: Unpin,
impl<T> UnwindSafe for WithStats<T>where
T: UnwindSafe,
Blanket Implementations§
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> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more