1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
use super::methods::LimitDsl;
use dsl::Limit;
use expression::grouped::Grouped;
use expression::subselect::Subselect;
use query_builder::SelectQuery;
use sql_types::{IntoNullable, SingleValue};

/// The `single_value` method
///
/// This trait should not be relied on directly by most apps. Its behavior is
/// provided by [`QueryDsl`]. However, you may need a where clause on this trait
/// to call `single_value` from generic code.
///
/// [`QueryDsl`]: ../trait.QueryDsl.html
pub trait SingleValueDsl {
    /// The type returned by `.single_value`.
    type Output;

    /// See the trait documentation.
    fn single_value(self) -> Self::Output;
}

impl<T, ST> SingleValueDsl for T
where
    Self: SelectQuery<SqlType = ST> + LimitDsl,
    ST: IntoNullable,
    ST::Nullable: SingleValue,
{
    type Output = Grouped<Subselect<Limit<Self>, ST::Nullable>>;

    fn single_value(self) -> Self::Output {
        Grouped(Subselect::new(self.limit(1)))
    }
}