- 建外部表使用LOCATION,读取到数据,同时插入数据,会在LOCATION位置新生成文件000000_0,然我删除外部表,数据文件还在,证明外部表功能还在。
- 我建内部表使用LOCATION,读取到数据,同时插入数据也会生成新文件,但如我删除内部表,数据文件都会消失,整个目录都会删除掉,也正好符合内部表的功能。
- 我建立外部表,不使用LOCATION,会在默认在/hive/warehouse/数据库名称/表名 建立目录,然后插入数据,会生成新文件,删除表。目录和文件都还在。符合外部表功能。
- 建立内部表,不使用LOCATION。在相应位置创建新目录,插入数据,一样生成新文件。但是如果删除内部表,目录和数据文件都会删除掉。
对比一下,发现是否用LOCATION方式建表,会影响在HDFS是否生成新目录(表名)。但是不影响外部表和内部表的功能。
转载文章,如有侵权联系立删~