From 41c2c49f5a67c567203f75bb7253e8a83d3aa1ac Mon Sep 17 00:00:00 2001 From: Solomon <108011288+abcpro1@users.noreply.github.com> Date: Thu, 28 Sep 2023 13:38:39 +0000 Subject: [PATCH] chore: remove unnecessary query in snowflake (#2099) Merge two queries, `EXISTS` and `CREATE`, into a single query `CREATE IF NOT EXISTS`. --- .../src/connectors/snowflake/connection/client.rs | 7 ------- .../src/connectors/snowflake/stream_consumer.rs | 11 ++++------- 2 files changed, 4 insertions(+), 14 deletions(-) diff --git a/dozer-ingestion/src/connectors/snowflake/connection/client.rs b/dozer-ingestion/src/connectors/snowflake/connection/client.rs index 100c2a03b7..6c0dc0acf6 100644 --- a/dozer-ingestion/src/connectors/snowflake/connection/client.rs +++ b/dozer-ingestion/src/connectors/snowflake/connection/client.rs @@ -237,13 +237,6 @@ impl<'env> Client<'env> { exec_first_exists(&self.pool, &query).map_or_else(Self::parse_not_exist_error, Ok) } - pub fn table_exist(&self, table_name: &String) -> Result { - let query = - format!("SELECT * FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_NAME = '{table_name}';"); - - exec_first_exists(&self.pool, &query).map_or_else(Self::parse_not_exist_error, Ok) - } - pub fn drop_stream(&self, stream_name: &String) -> Result { let query = format!("DROP STREAM IF EXISTS {stream_name}"); diff --git a/dozer-ingestion/src/connectors/snowflake/stream_consumer.rs b/dozer-ingestion/src/connectors/snowflake/stream_consumer.rs index 4ef1c6148c..a0838ab28a 100644 --- a/dozer-ingestion/src/connectors/snowflake/stream_consumer.rs +++ b/dozer-ingestion/src/connectors/snowflake/stream_consumer.rs @@ -102,16 +102,13 @@ impl StreamConsumer { ) -> Result<(), ConnectorError> { let temp_table_name = Self::get_stream_temp_table_name(table_name, &client.get_name()); let stream_name = Self::get_stream_table_name(table_name, &client.get_name()); - let temp_table_exist = client.table_exist(&temp_table_name)?; - if !temp_table_exist { - let query = format!( - "CREATE OR REPLACE TEMP TABLE {temp_table_name} AS + let query = format!( + "CREATE TEMP TABLE IF NOT EXISTS {temp_table_name} AS SELECT * FROM {stream_name} ORDER BY METADATA$ACTION;" - ); + ); - client.exec(&query)?; - } + client.exec(&query)?; let rows = client.fetch(format!("SELECT * FROM {temp_table_name};"))?; if let Some(schema) = rows.schema() {