mod aggregate_to_string;
mod average;
mod coalesce;
mod concat;
mod count;
mod json_array_agg;
mod json_build_obj;
#[cfg(any(feature = "postgresql", feature = "mysql"))]
mod json_extract;
#[cfg(any(feature = "postgresql", feature = "mysql"))]
mod json_extract_array;
#[cfg(any(feature = "postgresql", feature = "mysql"))]
mod json_unquote;
mod lower;
mod maximum;
mod minimum;
mod row_number;
#[cfg(feature = "postgresql")]
mod row_to_json;
#[cfg(any(feature = "postgresql", feature = "mysql"))]
mod search;
mod sum;
mod upper;
#[cfg(feature = "mysql")]
mod uuid;
pub use aggregate_to_string::*;
pub use average::*;
pub use coalesce::*;
pub use concat::*;
pub use count::*;
pub use json_array_agg::*;
pub use json_build_obj::*;
#[cfg(any(feature = "postgresql", feature = "mysql"))]
pub use json_extract::*;
#[cfg(any(feature = "postgresql", feature = "mysql"))]
pub(crate) use json_extract_array::*;
#[cfg(any(feature = "postgresql", feature = "mysql"))]
pub use json_unquote::*;
pub use lower::*;
pub use maximum::*;
pub use minimum::*;
pub use row_number::*;
#[cfg(feature = "postgresql")]
pub use row_to_json::*;
#[cfg(any(feature = "mysql", feature = "postgresql"))]
pub use search::*;
pub use sum::*;
pub use upper::*;
#[cfg(feature = "mysql")]
pub use self::uuid::*;
use super::{Aliasable, Expression};
use std::borrow::Cow;
#[derive(Debug, Clone, PartialEq)]
pub struct Function<'a> {
pub(crate) typ_: FunctionType<'a>,
pub(crate) alias: Option<Cow<'a, str>>,
}
impl<'a> Function<'a> {
pub fn returns_json(&self) -> bool {
match self.typ_ {
#[cfg(feature = "postgresql")]
FunctionType::RowToJson(_) => true,
#[cfg(feature = "mysql")]
FunctionType::JsonExtract(_) => true,
#[cfg(any(feature = "postgresql", feature = "mysql"))]
FunctionType::JsonExtractLastArrayElem(_) => true,
#[cfg(any(feature = "postgresql", feature = "mysql"))]
FunctionType::JsonExtractFirstArrayElem(_) => true,
_ => false,
}
}
}
#[derive(Debug, Clone, PartialEq)]
pub(crate) enum FunctionType<'a> {
#[cfg(feature = "postgresql")]
RowToJson(RowToJson<'a>),
RowNumber(RowNumber<'a>),
Count(Count<'a>),
AggregateToString(AggregateToString<'a>),
Average(Average<'a>),
Sum(Sum<'a>),
Lower(Lower<'a>),
Upper(Upper<'a>),
Minimum(Minimum<'a>),
Maximum(Maximum<'a>),
Coalesce(Coalesce<'a>),
Concat(Concat<'a>),
#[cfg(any(feature = "postgresql", feature = "mysql"))]
JsonExtract(JsonExtract<'a>),
#[cfg(any(feature = "postgresql", feature = "mysql"))]
JsonExtractLastArrayElem(JsonExtractLastArrayElem<'a>),
#[cfg(any(feature = "postgresql", feature = "mysql"))]
JsonExtractFirstArrayElem(JsonExtractFirstArrayElem<'a>),
#[cfg(any(feature = "postgresql", feature = "mysql"))]
JsonUnquote(JsonUnquote<'a>),
#[cfg(feature = "postgresql")]
JsonArrayAgg(JsonArrayAgg<'a>),
#[cfg(feature = "postgresql")]
JsonBuildObject(JsonBuildObject<'a>),
#[cfg(any(feature = "postgresql", feature = "mysql"))]
TextSearch(TextSearch<'a>),
#[cfg(any(feature = "postgresql", feature = "mysql"))]
TextSearchRelevance(TextSearchRelevance<'a>),
#[cfg(feature = "mysql")]
UuidToBin,
#[cfg(feature = "mysql")]
UuidToBinSwapped,
#[cfg(feature = "mysql")]
Uuid,
}
impl<'a> Aliasable<'a> for Function<'a> {
type Target = Function<'a>;
fn alias<T>(mut self, alias: T) -> Self::Target
where
T: Into<Cow<'a, str>>,
{
self.alias = Some(alias.into());
self
}
}
#[cfg(feature = "postgresql")]
function!(RowToJson);
#[cfg(any(feature = "postgresql", feature = "mysql"))]
function!(JsonExtract);
#[cfg(any(feature = "postgresql", feature = "mysql"))]
function!(JsonExtractLastArrayElem);
#[cfg(any(feature = "postgresql", feature = "mysql"))]
function!(JsonExtractFirstArrayElem);
#[cfg(any(feature = "postgresql", feature = "mysql"))]
function!(JsonUnquote);
#[cfg(any(feature = "postgresql", feature = "mysql"))]
function!(TextSearch);
#[cfg(any(feature = "postgresql", feature = "mysql"))]
function!(TextSearchRelevance);
function!(
RowNumber,
Count,
AggregateToString,
Average,
Sum,
Lower,
Upper,
Minimum,
Maximum,
Coalesce,
Concat,
JsonArrayAgg,
JsonBuildObject
);