Написание в Delta Table с использованием Spark SQLPython

Программы на Python
Ответить Пред. темаСлед. тема
Anonymous
 Написание в Delta Table с использованием Spark SQL

Сообщение Anonymous »

В Python я пытаюсь создать и записать в таблицу TBL в базе данных db в данных DataBricks. Но я получаю исключение: несоответствие схемы, обнаруженное при написании в таблице Delta . Мой код заключается в следующем, здесь df - это Pandas DataFrame.

Код: Выделить всё

from pyspark.sql import SparkSession

DB = database_name
TMP_TBL = temporary_table
TBL = table_name

sesh = SparkSession.builder.getOrCreate()
df_spark = sesh.createDataFrame(df)
df_spark.createOrReplaceTempView(TMP_TABLE)

create_db_query = f"""
CREATE DATABASE IF NOT EXISTS {DB}
COMMENT "This is a database"
LOCATION "/tmp/{DB}"
"""

create_table_query = f"""
CREATE TABLE IF NOT EXISTS {DB}.{TBL}
USING DELTA
TBLPROPERTIES (delta.autoOptimize.optimizeWrite = true, delta.autoOptimize.autoCompact = true)
COMMENT "This is a table"
LOCATION "/tmp/{DB}/{TBL}";
"""

insert_query = f"""
INSERT INTO TABLE {DB}.{TBL} select * from {TMP_TBL}
"""

sesh.sql(create_db_query)
sesh.sql(create_table_query)
sesh.sql(insert_query)
Код не удается в последней строке, insert_query строка. Когда я проверяю базу данных и таблицу, была создана, но, конечно, пуста. Таким образом, проблема заключается в том, что tmp_tbl и tbl имеют разные схемы, как и где я определяю схему, чтобы они соответствовали?

Подробнее здесь: https://stackoverflow.com/questions/752 ... -spark-sql
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение

Вернуться в «Python»