HIVE 表 DLL 基本操作(一)——第1关:Create/Alter/Drop 数据库

简介: HIVE 表 DLL 基本操作(一)——第1关:Create/Alter/Drop 数据库

任务描述

本关任务:根据编程要求对数据库进行相关操作。


相关知识

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


Create 创建数据库

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

创建数据库的语法为:

CREATE (DATABASE|SCHEMA) [IF NOT EXISTS] database_name
        [COMMENT database_comment]
        [LOCATION hdfs_path]
        [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
CREATE DATABASE IF NOT EXISTS shopping
LOCATION '/hive/shopping'
WITH DBPROPERTIES('creator'='Xiaoming','date'='2019-01-01');


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

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


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


Alter 修改数据库

修改数据库的语法为:

ALTER (DATABASE|SCHEMA)database_name SET DBPROPERTIES (property_name=property_valu
  • 只能修改数据库的键值对属性值。数据库名和数据库所在的目录位置不能修改


  1. 修改数据库shopping的键值对描述信息中的创建者信息,修改创建人为Xiaohong
ALTER DATABASE shopping SET DBPROPERTIES('creator'='Xiaohong');


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


Drop 删除数据库

选择使用数据库shopping

use shopping;


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

USE DEFAULT;


删除数据库语法:

DROP (DATABASE|SCHEMA) [IF EXISTS] database_name [RESTRICT|CASCADE];


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


  1. 删除数据库shopping,该操作会删除其位于HDFS上的shopping目录。
DROP DATABASE shopping;


编程要求

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

  • 创建数据库test1,位于HDFS/hive/test1下,创建人creatorJohn,创建日期date2019-02-25
  • 修改数据库test1的创建人为Marry
  • 删除数据库test1


按照以上要求填写命令。每个要求对应一条命令,共3条命令,以;隔开。

由于hive启动时间较长,测评时请耐心等待,大概需要时间:1-3分钟。


测试说明

补充完代码后,点击测评,平台会对你编写的代码进行测试,当你的结果与预期输出一致时,即为通过。


若操作成功,会显示如下信息:

st1数据库的信息如下:
test1        hdfs://localhost:9000/hive/test1    root    USER    {data=2019-02-25, creator=John}
修改后test1数据库的信息如下:
test1        hdfs://localhost:9000/hive/test1    root    USER    {date=2019-02-25, creator=Marry}
查看当前有哪些数据库:
default


#********* 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 *********#
目录
相关文章
|
4月前
|
存储 SQL 关系型数据库
关系型数据库sqlserver的DROP语句
【8月更文挑战第5天】
63 4
|
4月前
|
SQL 数据库 Windows
【应用服务 App Service】当使用EntityFrameWorkCore访问Sql Server数据库时,在Azure App Service会出现Cannot create a DbSet for ** because this type is not included in the model for the context的错误
【应用服务 App Service】当使用EntityFrameWorkCore访问Sql Server数据库时,在Azure App Service会出现Cannot create a DbSet for ** because this type is not included in the model for the context的错误
|
5月前
|
SQL 监控 关系型数据库
实时计算 Flink版操作报错合集之在设置监控PostgreSQL数据库时,将wal_level设置为logical,出现一些表更新和删除操作报错,怎么办
在使用实时计算Flink版过程中,可能会遇到各种错误,了解这些错误的原因及解决方法对于高效排错至关重要。针对具体问题,查看Flink的日志是关键,它们通常会提供更详细的错误信息和堆栈跟踪,有助于定位问题。此外,Flink社区文档和官方论坛也是寻求帮助的好去处。以下是一些常见的操作报错及其可能的原因与解决策略。
|
6月前
|
SQL 缓存 关系型数据库
ClickHouse(19)ClickHouse集成Hive表引擎详细解析
Hive引擎允许对HDFS Hive表执行 `SELECT` 查询。目前它支持如下输入格式: -文本:只支持简单的标量列类型,除了 `Binary` - ORC:支持简单的标量列类型,除了`char`; 只支持 `array` 这样的复杂类型 - Parquet:支持所有简单标量列类型;只支持 `array` 这样的复杂类型
223 1
|
6月前
|
SQL 存储 数据库
SQL 撤销索引、撤销表以及撤销数据库
SQL 撤销索引、撤销表以及撤销数据库
74 4
|
5月前
|
SQL Java 持续交付
实时计算 Flink版产品使用问题之源数据库一直在新增表或修改表结构,需要进行相应的修改和重启,该如何简化
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
|
6月前
|
SQL 存储 数据管理
数据管理DMS产品使用合集之如何把整个数据库的表和数据全部导出来
阿里云数据管理DMS提供了全面的数据管理、数据库运维、数据安全、数据迁移与同步等功能,助力企业高效、安全地进行数据库管理和运维工作。以下是DMS产品使用合集的详细介绍。
103 2
|
5月前
|
数据库
数据库bug-[08001] Could not create connection to database server. Attempted reconnect 3,主机名ip必须写对
数据库bug-[08001] Could not create connection to database server. Attempted reconnect 3,主机名ip必须写对
|
6月前
|
SQL Apache 数据库
doris数据库的表重命名语法是什么
【6月更文挑战第24天】doris数据库的表重命名语法是什么
1328 0
|
6月前
|
存储 数据库连接 数据库
逆向学习数据库篇:表设计和数据库操作的核心概念与流程
逆向学习数据库篇:表设计和数据库操作的核心概念与流程
37 0