Trait quaint::visitor::Visitor

source ·
pub trait Visitor<'a> {
    const C_BACKTICK_OPEN: &'static str;
    const C_BACKTICK_CLOSE: &'static str;
    const C_WILDCARD: &'static str;
Show 67 methods // Required methods fn build<Q>(query: Q) -> Result<(String, Vec<Value<'a>>)> where Q: Into<Query<'a>>; fn write<D: Display>(&mut self, s: D) -> Result; fn add_parameter(&mut self, value: Value<'a>); fn visit_limit_and_offset( &mut self, limit: Option<Value<'a>>, offset: Option<Value<'a>> ) -> Result; fn visit_ordering(&mut self, ordering: Ordering<'a>) -> Result; fn visit_insert(&mut self, insert: Insert<'a>) -> Result; fn parameter_substitution(&mut self) -> Result; fn visit_aggregate_to_string(&mut self, value: Expression<'a>) -> Result; fn visit_raw_value(&mut self, value: Value<'a>) -> Result; fn visit_json_extract(&mut self, json_extract: JsonExtract<'a>) -> Result; fn visit_json_extract_last_array_item( &mut self, extract: JsonExtractLastArrayElem<'a> ) -> Result; fn visit_json_extract_first_array_item( &mut self, extract: JsonExtractFirstArrayElem<'a> ) -> Result; fn visit_json_array_contains( &mut self, left: Expression<'a>, right: Expression<'a>, not: bool ) -> Result; fn visit_json_type_equals( &mut self, left: Expression<'a>, right: JsonType<'a>, not: bool ) -> Result; fn visit_json_unquote(&mut self, json_unquote: JsonUnquote<'a>) -> Result; fn visit_json_array_agg(&mut self, array_agg: JsonArrayAgg<'a>) -> Result; fn visit_json_build_object( &mut self, build_obj: JsonBuildObject<'a> ) -> Result; fn visit_text_search(&mut self, text_search: TextSearch<'a>) -> Result; fn visit_matches( &mut self, left: Expression<'a>, right: Cow<'a, str>, not: bool ) -> Result; fn visit_text_search_relevance( &mut self, text_search_relevance: TextSearchRelevance<'a> ) -> Result; // Provided methods fn compatibility_modifications(&self, query: Query<'a>) -> Query<'a> { ... } fn surround_with<F>(&mut self, begin: &str, end: &str, f: F) -> Result where F: FnOnce(&mut Self) -> Result { ... } fn columns_to_bracket_list(&mut self, columns: Vec<Column<'a>>) -> Result { ... } fn visit_parameterized_enum( &mut self, variant: EnumVariant<'a>, name: Option<EnumName<'a>> ) -> Result { ... } fn visit_parameterized_enum_array( &mut self, variants: Vec<EnumVariant<'a>>, name: Option<EnumName<'a>> ) -> Result { ... } fn visit_parameterized(&mut self, value: Value<'a>) -> Result { ... } fn visit_joins(&mut self, joins: Vec<Join<'a>>) -> Result { ... } fn visit_join_data(&mut self, data: JoinData<'a>) -> Result { ... } fn visit_select(&mut self, select: Select<'a>) -> Result { ... } fn visit_update(&mut self, update: Update<'a>) -> Result { ... } fn visit_upsert(&mut self, update: Update<'a>) -> Result { ... } fn visit_update_set(&mut self, update: Update<'a>) -> Result { ... } fn visit_delete(&mut self, delete: Delete<'a>) -> Result { ... } fn delimited_identifiers(&mut self, parts: &[&str]) -> Result { ... } fn surround_with_backticks(&mut self, part: &str) -> Result { ... } fn visit_merge(&mut self, _merge: Merge<'a>) -> Result { ... } fn visit_query(&mut self, query: Query<'a>) -> Result { ... } fn visit_sub_selection(&mut self, query: SelectQuery<'a>) -> Result { ... } fn visit_selection(&mut self, query: SelectQuery<'a>) -> Result { ... } fn visit_union(&mut self, ua: Union<'a>) -> Result { ... } fn visit_columns(&mut self, columns: Vec<Expression<'a>>) -> Result { ... } fn visit_operation(&mut self, op: SqlOp<'a>) -> Result { ... } fn visit_expression(&mut self, value: Expression<'a>) -> Result { ... } fn visit_multiple_tuple_comparison( &mut self, left: Row<'a>, right: Values<'a>, negate: bool ) -> Result { ... } fn visit_values(&mut self, values: Values<'a>) -> Result { ... } fn visit_table(&mut self, table: Table<'a>, include_alias: bool) -> Result { ... } fn visit_column(&mut self, column: Column<'a>) -> Result { ... } fn visit_row(&mut self, row: Row<'a>) -> Result { ... } fn visit_conditions(&mut self, tree: ConditionTree<'a>) -> Result { ... } fn visit_greater_than( &mut self, left: Expression<'a>, right: Expression<'a> ) -> Result { ... } fn visit_greater_than_or_equals( &mut self, left: Expression<'a>, right: Expression<'a> ) -> Result { ... } fn visit_less_than( &mut self, left: Expression<'a>, right: Expression<'a> ) -> Result { ... } fn visit_less_than_or_equals( &mut self, left: Expression<'a>, right: Expression<'a> ) -> Result { ... } fn visit_like( &mut self, left: Expression<'a>, right: Expression<'a> ) -> Result { ... } fn visit_not_like( &mut self, left: Expression<'a>, right: Expression<'a> ) -> Result { ... } fn visit_compare(&mut self, compare: Compare<'a>) -> Result { ... } fn visit_equals( &mut self, left: Expression<'a>, right: Expression<'a> ) -> Result { ... } fn visit_not_equals( &mut self, left: Expression<'a>, right: Expression<'a> ) -> Result { ... } fn visit_grouping(&mut self, grouping: Grouping<'a>) -> Result { ... } fn visit_average(&mut self, avg: Average<'a>) -> Result { ... } fn visit_min(&mut self, min: Minimum<'a>) -> Result { ... } fn visit_max(&mut self, max: Maximum<'a>) -> Result { ... } fn visit_function(&mut self, fun: Function<'a>) -> Result { ... } fn visit_concat(&mut self, concat: Concat<'a>) -> Result { ... } fn visit_partitioning(&mut self, over: Over<'a>) -> Result { ... } fn visit_cte(&mut self, cte: CommonTableExpression<'a>) -> Result { ... } fn visit_comment(&mut self, comment: Cow<'a, str>) -> Result { ... }
}
Expand description

A function travelling through the query AST, building the final query string and gathering parameters sent to the database together with the query.

Required Associated Constants§

source

const C_BACKTICK_OPEN: &'static str

Opening backtick character to surround identifiers, such as column and table names.

source

const C_BACKTICK_CLOSE: &'static str

Closing backtick character to surround identifiers, such as column and table names.

source

const C_WILDCARD: &'static str

Wildcard character to be used in LIKE queries.

Required Methods§

source

fn build<Q>(query: Q) -> Result<(String, Vec<Value<'a>>)>where Q: Into<Query<'a>>,

Convert the given Query to an SQL string and a vector of parameters. When certain parameters are replaced with the C_PARAM character in the query, the vector should contain the parameter value in the right position.

The point of entry for visiting query ASTs.

let query = Select::from_table("cats");
let (sqlite, _) = Sqlite::build(query.clone())?;
let (psql, _) = Postgres::build(query.clone())?;
let (mysql, _) = Mysql::build(query.clone())?;
let (mssql, _) = Mssql::build(query.clone())?;

assert_eq!("SELECT `cats`.* FROM `cats`", sqlite);
assert_eq!("SELECT \"cats\".* FROM \"cats\"", psql);
assert_eq!("SELECT `cats`.* FROM `cats`", mysql);
assert_eq!("SELECT [cats].* FROM [cats]", mssql);
source

fn write<D: Display>(&mut self, s: D) -> Result

Write to the query.

source

fn add_parameter(&mut self, value: Value<'a>)

When called, the visitor decided to not render the parameter into the query, replacing it with the C_PARAM, calling add_parameter with the replaced value.

source

fn visit_limit_and_offset( &mut self, limit: Option<Value<'a>>, offset: Option<Value<'a>> ) -> Result

The LIMIT and OFFSET statement in the query

source

fn visit_ordering(&mut self, ordering: Ordering<'a>) -> Result

A visit in the ORDER BY section of the query

source

fn visit_insert(&mut self, insert: Insert<'a>) -> Result

A walk through an INSERT statement

source

fn parameter_substitution(&mut self) -> Result

What to use to substitute a parameter in the query.

source

fn visit_aggregate_to_string(&mut self, value: Expression<'a>) -> Result

What to use to substitute a parameter in the query.

source

fn visit_raw_value(&mut self, value: Value<'a>) -> Result

Visit a non-parameterized value.

source

fn visit_json_extract(&mut self, json_extract: JsonExtract<'a>) -> Result

source

fn visit_json_extract_last_array_item( &mut self, extract: JsonExtractLastArrayElem<'a> ) -> Result

source

fn visit_json_extract_first_array_item( &mut self, extract: JsonExtractFirstArrayElem<'a> ) -> Result

source

fn visit_json_array_contains( &mut self, left: Expression<'a>, right: Expression<'a>, not: bool ) -> Result

source

fn visit_json_type_equals( &mut self, left: Expression<'a>, right: JsonType<'a>, not: bool ) -> Result

source

fn visit_json_unquote(&mut self, json_unquote: JsonUnquote<'a>) -> Result

source

fn visit_json_array_agg(&mut self, array_agg: JsonArrayAgg<'a>) -> Result

source

fn visit_json_build_object(&mut self, build_obj: JsonBuildObject<'a>) -> Result

source

fn visit_matches( &mut self, left: Expression<'a>, right: Cow<'a, str>, not: bool ) -> Result

source

fn visit_text_search_relevance( &mut self, text_search_relevance: TextSearchRelevance<'a> ) -> Result

Provided Methods§

source

fn compatibility_modifications(&self, query: Query<'a>) -> Query<'a>

A point to modify an incoming query to make it compatible with the underlying database.

source

fn surround_with<F>(&mut self, begin: &str, end: &str, f: F) -> Resultwhere F: FnOnce(&mut Self) -> Result,

source

fn columns_to_bracket_list(&mut self, columns: Vec<Column<'a>>) -> Result

source

fn visit_parameterized_enum( &mut self, variant: EnumVariant<'a>, name: Option<EnumName<'a>> ) -> Result

source

fn visit_parameterized_enum_array( &mut self, variants: Vec<EnumVariant<'a>>, name: Option<EnumName<'a>> ) -> Result

source

fn visit_parameterized(&mut self, value: Value<'a>) -> Result

A visit to a value we parameterize

source

fn visit_joins(&mut self, joins: Vec<Join<'a>>) -> Result

The join statements in the query

source

fn visit_join_data(&mut self, data: JoinData<'a>) -> Result

source

fn visit_select(&mut self, select: Select<'a>) -> Result

A walk through a SELECT statement

source

fn visit_update(&mut self, update: Update<'a>) -> Result

A walk through an UPDATE statement

source

fn visit_upsert(&mut self, update: Update<'a>) -> Result

source

fn visit_update_set(&mut self, update: Update<'a>) -> Result

source

fn visit_delete(&mut self, delete: Delete<'a>) -> Result

A walk through an DELETE statement

source

fn delimited_identifiers(&mut self, parts: &[&str]) -> Result

A helper for delimiting an identifier, surrounding every part with C_BACKTICK and delimiting the values with a .

source

fn surround_with_backticks(&mut self, part: &str) -> Result

A helper for delimiting a part of an identifier, surrounding it with C_BACKTICK

source

fn visit_merge(&mut self, _merge: Merge<'a>) -> Result

Visit an SQL MERGE query.

source

fn visit_query(&mut self, query: Query<'a>) -> Result

A walk through a complete Query statement

source

fn visit_sub_selection(&mut self, query: SelectQuery<'a>) -> Result

source

fn visit_selection(&mut self, query: SelectQuery<'a>) -> Result

source

fn visit_union(&mut self, ua: Union<'a>) -> Result

A walk through a union of SELECT statements

source

fn visit_columns(&mut self, columns: Vec<Expression<'a>>) -> Result

The selected columns

source

fn visit_operation(&mut self, op: SqlOp<'a>) -> Result

source

fn visit_expression(&mut self, value: Expression<'a>) -> Result

A visit to a value used in an expression

source

fn visit_multiple_tuple_comparison( &mut self, left: Row<'a>, right: Values<'a>, negate: bool ) -> Result

source

fn visit_values(&mut self, values: Values<'a>) -> Result

source

fn visit_table(&mut self, table: Table<'a>, include_alias: bool) -> Result

A database table identifier

source

fn visit_column(&mut self, column: Column<'a>) -> Result

A database column identifier

source

fn visit_row(&mut self, row: Row<'a>) -> Result

A row of data used as an expression

source

fn visit_conditions(&mut self, tree: ConditionTree<'a>) -> Result

A walk through the query conditions

source

fn visit_greater_than( &mut self, left: Expression<'a>, right: Expression<'a> ) -> Result

source

fn visit_greater_than_or_equals( &mut self, left: Expression<'a>, right: Expression<'a> ) -> Result

source

fn visit_less_than( &mut self, left: Expression<'a>, right: Expression<'a> ) -> Result

source

fn visit_less_than_or_equals( &mut self, left: Expression<'a>, right: Expression<'a> ) -> Result

source

fn visit_like(&mut self, left: Expression<'a>, right: Expression<'a>) -> Result

source

fn visit_not_like( &mut self, left: Expression<'a>, right: Expression<'a> ) -> Result

source

fn visit_compare(&mut self, compare: Compare<'a>) -> Result

A comparison expression

source

fn visit_equals( &mut self, left: Expression<'a>, right: Expression<'a> ) -> Result

source

fn visit_not_equals( &mut self, left: Expression<'a>, right: Expression<'a> ) -> Result

source

fn visit_grouping(&mut self, grouping: Grouping<'a>) -> Result

A visit in the GROUP BY section of the query

source

fn visit_average(&mut self, avg: Average<'a>) -> Result

source

fn visit_min(&mut self, min: Minimum<'a>) -> Result

source

fn visit_max(&mut self, max: Maximum<'a>) -> Result

source

fn visit_function(&mut self, fun: Function<'a>) -> Result

source

fn visit_concat(&mut self, concat: Concat<'a>) -> Result

source

fn visit_partitioning(&mut self, over: Over<'a>) -> Result

source

fn visit_cte(&mut self, cte: CommonTableExpression<'a>) -> Result

source

fn visit_comment(&mut self, comment: Cow<'a, str>) -> Result

Object Safety§

This trait is not object safe.

Implementors§

source§

impl<'a> Visitor<'a> for Mssql<'a>

source§

const C_BACKTICK_OPEN: &'static str = "["

source§

const C_BACKTICK_CLOSE: &'static str = "]"

source§

const C_WILDCARD: &'static str = "%"

source§

impl<'a> Visitor<'a> for Mysql<'a>

source§

const C_BACKTICK_OPEN: &'static str = "`"

source§

const C_BACKTICK_CLOSE: &'static str = "`"

source§

const C_WILDCARD: &'static str = "%"

source§

impl<'a> Visitor<'a> for Postgres<'a>

source§

const C_BACKTICK_OPEN: &'static str = "\""

source§

const C_BACKTICK_CLOSE: &'static str = "\""

source§

const C_WILDCARD: &'static str = "%"

source§

impl<'a> Visitor<'a> for Sqlite<'a>

source§

const C_BACKTICK_OPEN: &'static str = "`"

source§

const C_BACKTICK_CLOSE: &'static str = "`"

source§

const C_WILDCARD: &'static str = "%"