diesel/expression/
subselect.rs1use std::marker::PhantomData;
2
3use crate::expression::array_comparison::InExpression;
4use crate::expression::*;
5use crate::query_builder::*;
6use crate::result::QueryResult;
7
8#[derive(#[automatically_derived]
impl<T: ::core::fmt::Debug, ST: ::core::fmt::Debug> ::core::fmt::Debug for
Subselect<T, ST> {
#[inline]
fn fmt(&self, f: &mut ::core::fmt::Formatter) -> ::core::fmt::Result {
::core::fmt::Formatter::debug_struct_field2_finish(f, "Subselect",
"values", &self.values, "_sql_type", &&self._sql_type)
}
}Debug, #[automatically_derived]
impl<T: ::core::marker::Copy, ST: ::core::marker::Copy> ::core::marker::Copy
for Subselect<T, ST> {
}Copy, #[automatically_derived]
impl<T: ::core::clone::Clone, ST: ::core::clone::Clone> ::core::clone::Clone
for Subselect<T, ST> {
#[inline]
fn clone(&self) -> Subselect<T, ST> {
Subselect {
values: ::core::clone::Clone::clone(&self.values),
_sql_type: ::core::clone::Clone::clone(&self._sql_type),
}
}
}Clone, const _: () =
{
use diesel;
#[allow(non_camel_case_types)]
impl<T: diesel::query_builder::QueryId,
ST: diesel::query_builder::QueryId> diesel::query_builder::QueryId
for Subselect<T, ST> {
type QueryId =
Subselect<<T as diesel::query_builder::QueryId>::QueryId,
<ST as diesel::query_builder::QueryId>::QueryId>;
const HAS_STATIC_QUERY_ID: bool =
<T as diesel::query_builder::QueryId>::HAS_STATIC_QUERY_ID &&
<ST as diesel::query_builder::QueryId>::HAS_STATIC_QUERY_ID
&& true;
const IS_WINDOW_FUNCTION: bool =
<T as diesel::query_builder::QueryId>::IS_WINDOW_FUNCTION ||
<ST as diesel::query_builder::QueryId>::IS_WINDOW_FUNCTION
|| false;
}
};QueryId)]
18pub struct Subselect<T, ST> {
19 values: T,
20 _sql_type: PhantomData<ST>,
21}
22
23impl<T, ST> Subselect<T, ST> {
24 pub(crate) fn new(values: T) -> Self {
25 Self {
26 values,
27 _sql_type: PhantomData,
28 }
29 }
30}
31
32impl<T: SelectQuery, ST> Expression for Subselect<T, ST>
33where
34 ST: SqlType + TypedExpressionType,
35{
36 type SqlType = ST;
38}
39
40impl<T, ST: SqlType> InExpression for Subselect<T, ST> {
41 type SqlType = ST;
42 fn is_empty(&self) -> bool {
43 false
44 }
45 fn is_array(&self) -> bool {
46 false
47 }
48}
49
50impl<T, ST, QS> SelectableExpression<QS> for Subselect<T, ST>
51where
52 Subselect<T, ST>: AppearsOnTable<QS>,
53 T: ValidSubselect<QS>,
54{
55}
56
57impl<T, ST, QS> AppearsOnTable<QS> for Subselect<T, ST>
58where
59 Subselect<T, ST>: Expression,
60 T: ValidSubselect<QS>,
61{
62}
63
64impl<T, ST, GB> ValidGrouping<GB> for Subselect<T, ST> {
68 type IsAggregate = is_aggregate::Never;
69}
70
71impl<T, ST, DB> QueryFragment<DB> for Subselect<T, ST>
72where
73 DB: Backend,
74 T: QueryFragment<DB>,
75{
76 fn walk_ast<'b>(&'b self, mut out: AstPass<'_, 'b, DB>) -> QueryResult<()> {
77 self.values.walk_ast(out.reborrow())?;
78 Ok(())
79 }
80}
81
82pub trait ValidSubselect<QS> {}