Код: Выделить всё
def truncate_if_exists(self, connection_session, table_name):
"""Truncates table if it exists"""
check_query = f"""
SELECT 1
FROM INFORMATION_SCHEMA.TABLES
WHERE TABLE_NAME = '{table_name}'
"""
truncate_query = f"""
TRUNCATE TABLE {table_name}
"""
exists = connection_session.execute(text(check_query)).scalar()
if exists:
connection_session.execute(text(truncate_query))
Код: Выделить всё
UserWarning: The provided table name 'TEST_TABLE' is not found exactly as such in the database after writing the table, possibly due to case sensitivity issues. Consider using lower case table names.
Вот как используется эта функция:
Код: Выделить всё
from sqlalchemy import create_engine
from sqlalchemy.orm import sessionmaker
from sqlalchemy.sql import text
conn_string = 'snowflake://{username}:{password}@{account_identifier}/{schema}/{database}?warehouse={warehouse}&role=SYSADMIN'
conn_engine = create_engine(conn_string)
conn_session = sessionmaker(bind=conn_engine)
land_table = 'TEST_TABLE'
session = conn_session()
truncate_if_exists(session, land_table)
session.close()
Кто-нибудь может сообщить, почему она не усекается и передать это сообщение на Python?
EDIT: решено. Причина, по которой усечение не прошло, заключалась в том, что мне нужен был явный session.commit(). Меня ввело в заблуждение предупреждающее сообщение, и я до сих пор не понимаю, почему я это получаю.
Подробнее здесь: https://stackoverflow.com/questions/791 ... ing-python
Мобильная версия