hive07


4.5.1 管理表 1)理论 默认创建的表都是所谓的管理表,有时也被称为内部表。因为这种表,Hive 会(或多或 少地)控制着数据的生命周期。Hive 默认情况下会将这些表的数据存储在由配置项 hive.metastore.warehouse.dir(例如,/user/hive/warehouse)所定义的目录的子目录下。 当我们删除一个管理表时,Hive 也会删除这个表中数据。管理表不适合和其他工具共享 数据。 2)案例实操 (0)原始数据 1001 ss1 1002 ss2 1003 ss3 1004 ss4 1005 ss5 1006 ss6 1007 ss7 1008 ss8 1009 ss9 1010 ss10 1011 ss11 1012 ss12 1013 ss13 1014 ss14 1015 ss15 1016 ss16 (1)普通创建表 create table if not exists student( id int, name string ) row format delimited fields terminated by '\t' stored as textfile location '/user/hive/warehouse/student'; (2)根据查询结果创建表(查询的结果会添加到新创建的表中) create table if not exists student2 as select id, name from student; (3)根据已经存在的表结构创建表 create table if not exists student3 like student; (4)查询表的类型 hive (default)> desc formatted student2; Table Type: MANAGED_TABLE 4.5.2 外部表 1)理论 因为表是外部表,所以 Hive 并非认为其完全拥有这份数据。删除该表并不会删除掉这 份数据,不过描述表的元数据信息会被删除掉。 2)管理表和外部表的使用场景 每天将收集到的网站日志定期流入 HDFS 文本文件。在外部表(原始日志表)的基础上 做大量的统计分析,用到的中间表、结果表使用内部表存储,数据通过 SELECT+INSERT 进入 内部表。 3)案例实操 分别创建部门和员工外部表,并向表中导入数据。 (0)原始数据 dept: 10 ACCOUNTING 1700 20 RESEARCH 1800 30 SALES 1900 40 OPERATIONS 1700 emp: 7369 SMITH CLERK 7902 1980-12-17 800.00 20 7499 ALLEN SALESMAN 7698 1981-2-20 1600.00 300.00 30 7521 WARD SALESMAN 7698 1981-2-22 1250.00 500.00 30 7566 JONES MANAGER 7839 1981-4-2 2975.00 20 7654 MARTIN SALESMAN 7698 1981-9-28 1250.00 1400.00 30 7698 BLAKE MANAGER 7839 1981-5-1 2850.00 30 7782 CLARK MANAGER 7839 1981-6-9 2450.00 10 7788 SCOTT ANALYST 7566 1987-4-19 3000.00 20 7839 KING PRESIDENT 1981-11-17 5000.00 10 7844 TURNER SALESMAN 7698 1981-9-8 1500.00 0.00 30 7876 ADAMS CLERK 7788 1987-5-23 1100.00 20 7900 JAMES CLERK 7698 1981-12-3 950.00 30 7902 FORD ANALYST 7566 1981-12-3 3000.00 20 7934 MILLER CLERK 7782 1982-1-23 1300.00 10 (1)上传数据到 HDFS hive (default)> dfs -mkdir /student; hive (default)> dfs -put /opt/module/datas/student.txt /student; (2)建表语句,创建外部表 创建部门表 create external table if not exists dept( deptno int, dname string, loc int ) row format delimited fields terminated by '\t'; 创建员工表 create external table if not exists emp( empno int, ename string, job string, mgr int, hiredate string, sal double, comm double, deptno int) row format delimited fields terminated by '\t'; (3)查看创建的表 hive (default)>show tables;   (4)查看表格式化数据 hive (default)> desc formatted dept; Table Type: EXTERNAL_TABLE (5)删除外部表 hive (default)> drop table dept; 外部表删除后,hdfs 中的数据还在,但是 metadata 中 dept 的元数据已被删除 4.5.3 管理表与外部表的互相转换 (1)查询表的类型 hive (default)> desc formatted student2; Table Type: MANAGED_TABLE (2)修改内部表 student2 为外部表 alter table student2 set tblproperties('EXTERNAL'='TRUE'); (3)查询表的类型 hive (default)> desc formatted student2; Table Type: EXTERNAL_TABLE (4)修改外部表 student2 为内部表 alter table student2 set tblproperties('EXTERNAL'='FALSE'); (5)查询表的类型 hive (default)> desc formatted student2; Table Type: MANAGED_TABLE 注意:('EXTERNAL'='TRUE')和('EXTERNAL'='FALSE')为固定写法,区分大小写!