【Hive】drop table需注意外部表

什么是内部表,外部表?

比较专业的定义:

外部表需要转为内部表,执行删除操作才能真的删表结构删表数据。否则drop table仅是删除了表数据,表结构还是存在的。

alter table tb_name set TBLPROPERTIES('EXTERNAL'='false');

这个只是把表设成内部表,如果表本身是外部表的话。如果你本来表就是内部表就不用执行这个

drop table if exists tb_name ;

Q: 内部外部是对生产账号来说的对吗?

A: 不是,内部,外部,是表的一个类型,跟生产帐号没有关系。如果是外部表,你DROP的时候只会删除表分区,但表的文件依然存在,不会做清理。

所以,如果是外部表,你在DROP的时候相当于没有做清理

注意用spark执行会报错,以下语句要使用hive执行。

ALTER TABLE tb_name SET TBLPROPERTIES('EXTERNAL' = 'FALSE');

报错信息:

INFO Error in query: Cannot set or change the preserved property key: 'EXTERNAL';

在知乎看到的解决方案:https://zhuanlan.zhihu.com/p/161771826

(其实并没有说怎么解决,可能只能hive引擎使用)

相关推荐
sin220110 分钟前
Hive数据仓库中的数据导出到MySQL的数据表不成功
数据仓库·hive·mysql
m0_7482400244 分钟前
基于Hadoop的汽车大数据分析系统设计与实现【爬虫、数据预处理、MapReduce、echarts、Flask】
hadoop·爬虫·汽车
黄雪超1 小时前
深入MapReduce——计算模型设计
大数据·hadoop·mapreduce
怎么才能努力学习啊6 小时前
Hive之加载csv格式数据到hive
数据仓库·hive·hadoop
黑客老李12 小时前
区块链 智能合约安全 | 回滚攻击
服务器·数据仓库·hive·hadoop·区块链·php·智能合约
qzWsong14 小时前
hive 自动检测、自动重启、记录检测日志、自动清理日志
数据仓库·hive·hadoop
milk_yan15 小时前
MinIO的安装与使用
linux·数据仓库·spring boot
Ray.199819 小时前
Flink 的核心特点和概念
大数据·数据仓库·数据分析·flink
lisacumt19 小时前
【kerberos】使用keytab文件,kerberos认证工具类 scala版本
hadoop·scala