from sqlalchemy.sql.ddl import DDL from sqlalchemy.exc import ArgumentError from clickhouse_connect.driver.binding import quote_identifier # pylint: disable=too-many-ancestors,abstract-method class CreateDatabase(DDL): """ SqlAlchemy DDL statement that is essentially an alternative to the built in CreateSchema DDL class """ # pylint: disable-msg=too-many-arguments def __init__(self, name: str, engine: str = None, zoo_path: str = None, shard_name: str = '{shard}', replica_name: str = '{replica}'): """ :param name: Database name :param engine: Database ClickHouse engine type :param zoo_path: ClickHouse zookeeper path for Replicated database engine :param shard_name: Clickhouse shard name for Replicated database engine :param replica_name: Replica name for Replicated database engine """ if engine and engine not in ('Ordinary', 'Atomic', 'Lazy', 'Replicated'): raise ArgumentError(f'Unrecognized engine type {engine}') stmt = f'CREATE DATABASE {quote_identifier(name)}' if engine: stmt += f' Engine {engine}' if engine == 'Replicated': if not zoo_path: raise ArgumentError('zoo_path is required for Replicated Database Engine') stmt += f" ('{zoo_path}', '{shard_name}', '{replica_name}'" super().__init__(stmt) # pylint: disable=too-many-ancestors,abstract-method class DropDatabase(DDL): """ Alternative DDL statement for built in SqlAlchemy DropSchema DDL class """ def __init__(self, name: str): super().__init__(f'DROP DATABASE {quote_identifier(name)}')