From 8164b7c316b0140b86d6cfd1b2b46ba3366452a7 Mon Sep 17 00:00:00 2001 From: Lukasz Stefaniak Date: Fri, 27 Oct 2023 11:45:18 +0200 Subject: [PATCH] common: Make sure + - * / % binary operators work the same in all dialects (#1025) --- src/dialect/bigquery.rs | 6 +--- tests/sqlparser_bigquery.rs | 2 -- tests/sqlparser_common.rs | 58 +++++++++++++++++++++++++++++++++++++ 3 files changed, 59 insertions(+), 7 deletions(-) diff --git a/src/dialect/bigquery.rs b/src/dialect/bigquery.rs index 46f27fea4..bcd27c3b5 100644 --- a/src/dialect/bigquery.rs +++ b/src/dialect/bigquery.rs @@ -27,10 +27,6 @@ impl Dialect for BigQueryDialect { } fn is_identifier_part(&self, ch: char) -> bool { - ch.is_ascii_lowercase() - || ch.is_ascii_uppercase() - || ch.is_ascii_digit() - || ch == '_' - || ch == '-' + ch.is_ascii_lowercase() || ch.is_ascii_uppercase() || ch.is_ascii_digit() || ch == '_' } } diff --git a/tests/sqlparser_bigquery.rs b/tests/sqlparser_bigquery.rs index 006927e46..04cca0b7c 100644 --- a/tests/sqlparser_bigquery.rs +++ b/tests/sqlparser_bigquery.rs @@ -615,8 +615,6 @@ fn parse_table_identifiers() { assert!(bigquery().parse_sql_statements(&sql).is_err()); } - test_table_ident("da-sh-es", None, vec![Ident::new("da-sh-es")]); - test_table_ident("`spa ce`", None, vec![Ident::with_quote('`', "spa ce")]); test_table_ident( diff --git a/tests/sqlparser_common.rs b/tests/sqlparser_common.rs index bae28dfa8..fcad2455a 100644 --- a/tests/sqlparser_common.rs +++ b/tests/sqlparser_common.rs @@ -7744,3 +7744,61 @@ fn parse_create_type() { fn parse_create_table_collate() { pg_and_generic().verified_stmt("CREATE TABLE tbl (foo INT, bar TEXT COLLATE \"de_DE\")"); } + +#[test] +fn parse_binary_operators_without_whitespace() { + // x + y + all_dialects().one_statement_parses_to( + "SELECT field+1000 FROM tbl1", + "SELECT field + 1000 FROM tbl1", + ); + + all_dialects().one_statement_parses_to( + "SELECT tbl1.field+tbl2.field FROM tbl1 JOIN tbl2 ON tbl1.id = tbl2.entity_id", + "SELECT tbl1.field + tbl2.field FROM tbl1 JOIN tbl2 ON tbl1.id = tbl2.entity_id", + ); + + // x - y + all_dialects().one_statement_parses_to( + "SELECT field-1000 FROM tbl1", + "SELECT field - 1000 FROM tbl1", + ); + + all_dialects().one_statement_parses_to( + "SELECT tbl1.field-tbl2.field FROM tbl1 JOIN tbl2 ON tbl1.id = tbl2.entity_id", + "SELECT tbl1.field - tbl2.field FROM tbl1 JOIN tbl2 ON tbl1.id = tbl2.entity_id", + ); + + // x * y + all_dialects().one_statement_parses_to( + "SELECT field*1000 FROM tbl1", + "SELECT field * 1000 FROM tbl1", + ); + + all_dialects().one_statement_parses_to( + "SELECT tbl1.field*tbl2.field FROM tbl1 JOIN tbl2 ON tbl1.id = tbl2.entity_id", + "SELECT tbl1.field * tbl2.field FROM tbl1 JOIN tbl2 ON tbl1.id = tbl2.entity_id", + ); + + // x / y + all_dialects().one_statement_parses_to( + "SELECT field/1000 FROM tbl1", + "SELECT field / 1000 FROM tbl1", + ); + + all_dialects().one_statement_parses_to( + "SELECT tbl1.field/tbl2.field FROM tbl1 JOIN tbl2 ON tbl1.id = tbl2.entity_id", + "SELECT tbl1.field / tbl2.field FROM tbl1 JOIN tbl2 ON tbl1.id = tbl2.entity_id", + ); + + // x % y + all_dialects().one_statement_parses_to( + "SELECT field%1000 FROM tbl1", + "SELECT field % 1000 FROM tbl1", + ); + + all_dialects().one_statement_parses_to( + "SELECT tbl1.field%tbl2.field FROM tbl1 JOIN tbl2 ON tbl1.id = tbl2.entity_id", + "SELECT tbl1.field % tbl2.field FROM tbl1 JOIN tbl2 ON tbl1.id = tbl2.entity_id", + ); +}