Hive表DDL操作(一) 第1关:Create/Alter/Drop 数据库

40 篇文章 5 订阅
17 篇文章 8 订阅

相关知识

为了完成本关任务,你需要掌握: 1.如何创建数据库; 2.如何修改数据库; 3.如何删除数据库。

Create 创建数据库

数据库本质上是一个目录或命名空间,用于解决表命名冲突。

创建数据库的语法为:

 
  1. CREATE (DATABASE|SCHEMA) [IF NOT EXISTS] database_name
  2. [COMMENT database_comment]
  3. [LOCATION hdfs_path]
  4. [WITH DBPROPERTIES (property_name=property_value,…)];
  • DATABASE|SCHEMA:用于限定创建数据库或数据库模式
  • IF NOT EXISTS:目标对象不存在时才执行创建操作(可选)
  • COMMENT:起注释说明作用
  • LOCATION:指定数据库位于HDFS上的存储路径。若未指定,将使用${hive.metastore.warehouse.dir}定义值作为其上层路径位置
  • WITH DBPROPERTIES:为数据库提供描述信息,如创建database的用户或时间
  1. 创建一个名为shopping的数据库,位于HDFS/hive/shopping下,创建人为Xiaoming,创建日期为:2019-01-01
 
  1. CREATE DATABASE IF NOT EXISTS shopping
  2. LOCATION '/hive/shopping'
  3. WITH DBPROPERTIES('creator'='Xiaoming','date'='2019-01-01');

说明:CREATE等关键字大小写均可。

  1. 使用exit;命令退出hive命令行模式,然后再用hdfs dfs -ls /hive查看HDFS上的目录,可以看出上述CREATE操作在HDFS/hive目录下创建了一个shopping目录。

  1. 使用命令查看数据库shopping的信息(若不指定关键字EXTENDED,则不会输出{}里的内容)。
 
  1. DESCRIBE DATABASE EXTENDED shopping;

Alter 修改数据库

修改数据库的语法为:

 
  1. ALTER (DATABASE|SCHEMA)database_name SET DBPROPERTIES (property_name=property_value,…);
  • 只能修改数据库的键值对属性值。数据库名和数据库所在的目录位置不能修改
  1. 修改数据库shopping的键值对描述信息中的创建者信息,修改创建人为Xiaohong
 
  1. ALTER DATABASE shopping SET DBPROPERTIES('creator'='Xiaohong');

  1. 使用命令查看修改后的数据库shopping的信息。
 
  1. DESCRIBE DATABASE EXTENDED shopping;

Drop 删除数据库

选择使用数据库shopping

 
  1. use shopping;

USE命令用于设定当前所有数据库对象操作所处的工作数据库,类似于Linux 文件系统中切换当前目录操作。若返回到default数据库,使用下述命令:

 
  1. USE DEFAULT;

删除数据库语法:

 
  1. DROP (DATABASE|SCHEMA) [IF EXISTS] database_name [RESTRICT|CASCADE];
  • DATABASE|SCHEMA:用于限定删除的数据库或数据库模式
  • IF EXISTS:目标对象存在时才执行删除操作(可选)
  • RESTRICT|CASCADERESTRICT为 Hive 默认操作方式,当database_name中不存在任何数据库对象时才能执行DROP操作;CASCADE 采用强制DROP方式,汇联通存在于database_name中的任何数据库对象和database_name一起删除(可选)
  1. 删除数据库shopping,该操作会删除其位于HDFS上的shopping目录。
 
  1. DROP DATABASE shopping;

编程要求

请根据右侧命令行内的提示,在Begin - End区域内进行sql语句代码补充,具体任务如下:

  • 创建数据库test1,位于HDFS/hive/test1下,创建人creatorJohn,创建日期date2019-02-25
  • 修改数据库test1的创建人为Marry
  • 删除数据库test1
#********* Begin *********#
echo "
CREATE DATABASE IF NOT EXISTS test1  
LOCATION '/hive/test1'  
WITH DBPROPERTIES('creator'='John','date'='2019-02-25');  
 
ALTER DATABASE test1 SET DBPROPERTIES('creator'='Marry');  
 
DROP DATABASE test1;  



"
#********* End *********#

  • 3
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
根据引用\[1\],错误信息显示无法确定路径是否加密,可能是由于路径不正确导致的。引用\[2\]提到,如果直接将批量文件夹上传到HDFS的路径下,Hive的元数据中不会记录新增的分区数据,需要执行`msck repair db.tablename`命令修复分区。引用\[3\]也提到了修复分区的情况,当手动复制目录到Hive的位置下或者频繁导入数据到HDFS时,Hive的元数据可能没有及时更新。因此,可能需要执行`msck repair`命令来修复分区并更新Hive的元数据。 #### 引用[.reference_title] - *1* [Hive -error- 数据仓库问题:FAILED: SemanticException Unable to determine if hdfs://master:9000/user/...](https://blog.csdn.net/li1351026473/article/details/116904190)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [Sparkthrift-sql执行报错-File does not exist: hdfs://xxx/t_bd_materialgroup/xxx.parquet](https://blog.csdn.net/weixin_42151880/article/details/128049960)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值