spark,读取和写入同一张表问题

读取a表,写入a表

1.写入的是分区表,不报错

2.读取上来之后,创建为临时视图temp,然后先写入a表,再使用temp,就会报错

解决办法:可以先使用temp,再写入a表

3.写入的不是分区表,会报错

解决办法:先把数据收集到Driver,创建临时视图,再写入a表

4.万能解决办法:先把数据收集到Driver,创建临时视图,再写入a表

java 复制代码
Dataset<Row> dataset = spark.sql(get_new_id_Sql());

StructType schema = dataset.schema();

List<Row> rows = dataset.collectAsList();

spark.createDataFrame(rows, schema).createOrReplaceTempView("all_data");
sql 复制代码
insert overwrite table ods.a
select * from all_data

可能的原因:spark是移动数据不如移动计算,所以数据的路径还是a表,如果收集到Driver,路径就不是a表了

相关推荐
Yuer202519 分钟前
用 Rust 做分布式查询引擎之前,我先写了一个最小执行 POC
开发语言·分布式·rust
智能化咨询36 分钟前
(99页PPT)智慧校园XXX学院总体解决方案(附下载方式)
大数据
张彦峰ZYF2 小时前
高并发场景下的缓存雪崩探析与应对策略
redis·分布式·缓存
wang_yb3 小时前
数据分析师的“水晶球”:时间序列分析
大数据·databook
ModestCoder_3 小时前
Git 版本管理教程
大数据·git·elasticsearch
hg01183 小时前
湖南工程机械海外火爆,非洲成为出口新增长极
大数据
乐迪信息4 小时前
乐迪信息:异物入侵识别算法上线,AI摄像机保障智慧煤矿生产稳定
大数据·运维·人工智能·物联网·安全
熬夜敲代码的小N4 小时前
从SEO到GEO:AI时代内容优化的范式革命
大数据·人工智能·计算机网络
DX_水位流量监测5 小时前
压力式水位计的技术特性与应用实践
大数据·网络·人工智能·安全·信息可视化
张彦峰ZYF5 小时前
高并发场景下的缓存穿透问题探析与应对策略
redis·分布式