Hive-内部表和外部表

区别

内部表实例

准备数据

查看数据

删除数据

外部表实例

准备数据

查看数据

删除数据


区别

内部表 :管理元数据(记录数据的文件和目录的信息)和数据。当删除内部表时,会删除数据和表的元数据,所以当多个表关联同一个文件时,其中一个表删除了,其他表也将会没有数据。

外部表:只管理元数据。删除表并不会影响其他表数据。【推荐】

内部表实例

准备数据

bash 复制代码
1,张三,工程部,75000
2,李四,市场部,80000
3,王五,财务部,85000
4,赵六,工程部,95000
5,孙七,人事部,60000

建库

bash 复制代码
-- 创建库
drop database if exists db_2 cascade;
create database db_2;
use db_2;

建表:分别创建3个内部表 依赖同一个文件

bash 复制代码
-- 1.1 创建内部表  依赖 文件1
CREATE TABLE IF NOT EXISTS db_2.employee (
    id INT,
    name STRING,
    department STRING,
    salary FLOAT
)
row format delimited fields terminated by ','
location '/test/external/employee_data'
;

select * from db_2.employee;

-- 1.2 创建内部表2 依赖 文件1
CREATE TABLE IF NOT EXISTS db_2.employee_2 (
    id INT,
    name STRING,
    department STRING,
    salary FLOAT
)
row format delimited fields terminated by ','
location '/test/external/employee_data'
;

select * from db_2.employee_2;

-- 1.3 创建内部表3 依赖 文件1
CREATE TABLE IF NOT EXISTS db_2.employee_3 (
    id INT,
    name STRING,
    department STRING,
    salary FLOAT
)
row format delimited fields terminated by ','
location '/test/external/employee_data'
;

select * from db_2.employee_3;

查看数据

bash 复制代码
-- 验证数据加载
SELECT * FROM tb_archer;

删除数据

bash 复制代码
-- 删除内部表1
drop table db_2.employee;

删除内部表后,数据也被删除了

删除内部表1,内部表2和内部表3没有数据

外部表实例

准备数据

bash 复制代码
-- 2.1 创建外部表  依赖 文件1
CREATE external TABLE IF NOT EXISTS db_2.tb_employee_external (
    id INT,
    name STRING,
    department STRING,
    salary FLOAT
)
row format delimited fields terminated by ','
location '/test/external/employee_data'
;

-- 1.2 创建外部表2 依赖 文件1
CREATE external TABLE IF NOT EXISTS db_2.tb_employee_external_2 (
    id INT,
    name STRING,
    department STRING,
    salary FLOAT
)
row format delimited fields terminated by ','
location '/test/external/employee_data'
;

-- 1.3 创建外部表3 依赖 文件1
CREATE external TABLE IF NOT EXISTS db_2.tb_employee_external_3 (
    id INT,
    name STRING,
    department STRING,
    salary FLOAT
)
row format delimited fields terminated by ','
location '/test/external/employee_data'
;

查看数据

bash 复制代码
select * from db_2.tb_employee_external;

删除数据

bash 复制代码
drop table db_2.tb_employee_external;

删除外部表,仍然还有数据,只是把元数据删除了

删除外部表后,其他关联数据的表仍有数据

相关推荐
小鸡脚来咯39 分钟前
Hive SQL与SQL不同处
hive·hadoop·sql
kylezhao20191 小时前
WinForm/WPF界面开发(常用控件、布局设计、事件处理)
大数据·hadoop·wpf
郑泰科技3 小时前
hbase 避坑F:\hbase\hadoop\sbin>start-dfs.cmd 系统找不到文件 hadoop。
大数据·数据库·hadoop·hdfs·hbase
郑泰科技3 小时前
hbase避坑:Hadoop 的 NameNode 找不到指定的存储目录
数据库·hadoop·hbase
zgl_2005377917 小时前
ZGLanguage 解析SQL数据血缘 之 提取select语句中的源表名
大数据·数据库·c++·数据仓库·sql·数据库开发·etl
宸津-代码粉碎机19 小时前
Spring 6.0+Boot 3.0实战避坑全指南:5大类高频问题与解决方案(附代码示例)
java·数据仓库·hive·hadoop·python·技术文档编写
`林中水滴`20 小时前
Hive系列:Hive 默认分隔符
hive
昌sit!1 天前
hadoop集群搭建
大数据·hadoop·分布式
yumgpkpm1 天前
银行的数据智能平台和Cloudera CDP 7.3(CMP 7.3)的技术对接
数据库·人工智能·hive·hadoop·elasticsearch·数据挖掘·kafka
`林中水滴`1 天前
Hive系列:Hive 配置项详解
hive