mod alter_table;
mod assignment;
mod build;
mod column_def;
mod column_list;
mod create_table;
mod data_type;
mod delete;
mod drop_table;
mod error;
mod execute;
mod expr;
mod expr_list;
mod expr_with_alias;
mod index;
mod index_item;
mod insert;
mod order_by_expr;
mod order_by_expr_list;
mod query;
mod select;
mod select_item;
mod select_item_list;
mod show_columns;
mod table_factor;
mod table_name;
mod transaction;
mod update;
pub use {
assignment::AssignmentNode,
build::Build,
column_def::ColumnDefNode,
column_list::ColumnList,
create_table::CreateTableNode,
data_type::DataTypeNode,
delete::DeleteNode,
drop_table::DropTableNode,
error::AstBuilderError,
execute::Execute,
expr_list::ExprList,
expr_with_alias::ExprWithAliasNode,
index_item::{
non_clustered, primary_key, CmpExprNode, IndexItemNode, NonClusteredNode, PrimaryKeyNode,
},
insert::InsertNode,
order_by_expr::OrderByExprNode,
order_by_expr_list::OrderByExprList,
query::QueryNode,
select::{
select, values, FilterNode, GroupByNode, HashJoinNode, HavingNode, JoinConstraintNode,
JoinNode, LimitNode, OffsetLimitNode, OffsetNode, OrderByNode, ProjectNode, SelectNode,
},
select_item::SelectItemNode,
select_item_list::SelectItemList,
show_columns::ShowColumnsNode,
table_factor::{
glue_indexes, glue_objects, glue_table_columns, glue_tables, series, TableFactorNode,
},
table_name::table,
update::UpdateNode,
};
pub use expr::{
bitwise_not, case, col, date, exists, expr, factorial, minus, nested, not, not_exists, null,
num, numeric::NumericNode, plus, subquery, text, time, timestamp, ExprNode,
};
pub use alter_table::{
AddColumnNode, AlterTableNode, DropColumnNode, RenameColumnNode, RenameTableNode,
};
pub use {index::CreateIndexNode, index::DropIndexNode};
pub use expr::{
aggregate::{avg, count, max, min, stdev, sum, variance, AggregateNode},
function,
};
pub use transaction::{begin, commit, rollback};
#[cfg(test)]
fn test(actual: crate::result::Result<crate::ast::Statement>, expected: &str) {
use crate::{parse_sql::parse, translate::translate};
let parsed = &parse(expected).expect(expected)[0];
let expected = translate(parsed);
pretty_assertions::assert_eq!(actual, expected);
}
#[cfg(test)]
fn test_expr(actual: crate::ast_builder::ExprNode, expected: &str) {
use crate::{parse_sql::parse_expr, translate::translate_expr};
let parsed = &parse_expr(expected).expect(expected);
let expected = translate_expr(parsed);
pretty_assertions::assert_eq!(actual.try_into(), expected);
}
#[cfg(test)]
fn test_query(actual: crate::ast_builder::QueryNode, expected: &str) {
use crate::{parse_sql::parse_query, translate::translate_query};
let parsed = &parse_query(expected).expect(expected);
let expected = translate_query(parsed);
pretty_assertions::assert_eq!(actual.try_into(), expected);
}