quaint 0.1.13

An abstraction layer for SQL databases.
Documentation
use crate::ast::DatabaseValue;

#[derive(Debug, Clone, PartialEq)]
/// An aggregate function that concatenates strings from a group into a single
/// string with various options.
pub struct AggregateToString<'a> {
    pub(crate) value: Box<DatabaseValue<'a>>,
}

/// Aggregates the given field into a string.
///
/// ```rust
/// # use quaint::{ast::*, visitor::{Visitor, Sqlite}};
/// let query = Select::from_table("users").value(aggregate_to_string(Column::new("firstName")))
///     .group_by("firstName");
///
/// let (sql, _) = Sqlite::build(query);
/// assert_eq!("SELECT GROUP_CONCAT(`firstName`) FROM `users` GROUP BY `firstName`", sql);
/// ```
#[inline]
pub fn aggregate_to_string<'a, T>(expr: T) -> AggregateToString<'a>
where
    T: Into<DatabaseValue<'a>>,
{
    AggregateToString {
        value: Box::new(expr.into()),
    }
}