Spark 写Hive出现HiveFileFormat. It doesn't match the specified format 错误

背景:

在 python spark 任务中,调用

lua 复制代码
df.repartition("a","b","c").write.format("parquet").mode(saveMode).partitionBy("date").saveAsTable("table_name")

出现报错,提示:

swift 复制代码
org.apache.spark.sql.AnalysisException: The format of the existing table xxx is `HiveFileFormat`. It doesn't match the specified format `ParquetFileFormat`.

提示我们写入 hive 的 fileformat 不对。

这个报错在 spark 1.x 版本不会报错,在 spark 2.x 版本开始出现。

解决方案

  1. 如果我们的 hive 表不是分区表。将format("parquet")改成 format("hive")即可。

将format设置为Hive以后,无论hive建表的时候,使用的fileformat使用的是哪一种,都没有关系。

  1. 如果我们的 hive 表是分区表,可以先将数据存到一个临时表,再调用 spark.sql 插入数据。
python 复制代码
        df = spark.createDataFrame(data, ["a", "b", "c", "ctime"])
        df.createOrReplaceTempView("temp_view")
        spark.sql("""
        INSERT INTO $hive_table_name PARTITION (date = '{}')
        select * from temp_view
        """.format(date))
相关推荐
哈哈很哈哈16 分钟前
Spark 核心 RDD详解
大数据·分布式·spark·scala
智海观潮19 分钟前
Spark广播变量HttpBroadcast和TorrentBroadcast对比
大数据·spark
ERP老兵_冷溪虎山27 分钟前
Python/JS/Go/Java同步学习(第十三篇)四语言“字符串转码解码“对照表: 财务“小南“纸式转码术处理凭证乱码崩溃(附源码/截图/参数表/避坑指南)
java·后端·python
独行soc1 小时前
2025年渗透测试面试题总结-67(题目+回答)
网络·python·安全·web安全·网络安全·adb·渗透测试
eybk2 小时前
用python的socket写一个局域网传输文件的程序
服务器·网络·python
程序员的世界你不懂2 小时前
【Flask】实现一个前后端一体的项目-脚手架
后端·python·flask
花酒锄作田2 小时前
[MCP][01]简介与概念
python·llm·mcp
Python私教2 小时前
Django全栈班v1.04 Python基础语法 20250912 上午
后端·python·django
言之。2 小时前
Django REST框架:ModelViewSet全面解析
数据库·python·django
Pocker_Spades_A3 小时前
Python快速入门专业版(二十六):Python函数基础:定义、调用与返回值(Hello函数案例)
开发语言·python