From 60c408abae5a3903a8a5d556f43f8ea785755915 Mon Sep 17 00:00:00 2001 From: Peter Kay Date: Fri, 4 Oct 2024 16:28:27 +0100 Subject: [PATCH] feat: adding drop table if exists and alembic render import --- src/databricks/sqlalchemy/_ddl.py | 10 ++++++++++ src/databricks/sqlalchemy/base.py | 1 + 2 files changed, 11 insertions(+) diff --git a/src/databricks/sqlalchemy/_ddl.py b/src/databricks/sqlalchemy/_ddl.py index 633dfc49..082407e1 100644 --- a/src/databricks/sqlalchemy/_ddl.py +++ b/src/databricks/sqlalchemy/_ddl.py @@ -101,6 +101,16 @@ def visit_create_table(self, create, **kw): return text + def liquid_cluster_on_table(self, liquid_cluster_columns): + columns = liquid_cluster_columns + + return """CLUSTER BY ({cols})""".format(cols=', '.join(columns)) + + def visit_drop_table(self, drop, **kw): + text = "\nDROP TABLE IF EXISTS " + + return text + self.preparer.format_table(drop.element) + def visit_unique_constraint(self, constraint, **kw): logger.warning("Databricks does not support unique constraints") pass diff --git a/src/databricks/sqlalchemy/base.py b/src/databricks/sqlalchemy/base.py index f7ecc266..fd769861 100644 --- a/src/databricks/sqlalchemy/base.py +++ b/src/databricks/sqlalchemy/base.py @@ -32,6 +32,7 @@ pass else: from alembic.ddl import DefaultImpl + from alembic.autogenerate import render class DatabricksImpl(DefaultImpl): __dialect__ = "databricks"