第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
的用户或时间
- 创建一个名为
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
等关键字大小写均可。*
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-IfxFMmxW-1666829105613)(https://data.educoder.net/api/attachments/279583)]
- 使用
exit;
命令退出hive
命令行模式,然后再用hdfs dfs -ls /hive
查看HDFS
上的目录,可以看出上述CREATE
操作在HDFS
的/hive
目录下创建了一个shopping
目录。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-nshgkGNs-1666829105615)(https://data.educoder.net/api/attachments/279188)]
- 使用命令查看数据库
shopping
的信息(若不指定关键字EXTENDED
,则不会输出{}
里的内容)。
DESCRIBE DATABASE EXTENDED shopping;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-2WJb1P89-1666829105616)(https://data.educoder.net/api/attachments/279584)]
Alter 修改数据库
修改数据库的语法为:
ALTER (DATABASE|SCHEMA)database_name SET DBPROPERTIES (property_name=property_value,…);
- 只能修改数据库的键值对属性值。数据库名和数据库所在的目录位置不能修改
- 修改数据库
shopping
的键值对描述信息中的创建者信息,修改创建人为Xiaohong
。
ALTER DATABASE shopping SET DBPROPERTIES('creator'='Xiaohong');
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Djg9mlCf-1666829105616)(https://data.educoder.net/api/attachments/279195)]
- 使用命令查看修改后的数据库
shopping
的信息。
DESCRIBE DATABASE EXTENDED shopping;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-n3ovgi7l-1666829105618)(https://data.educoder.net/api/attachments/279585)]
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
一起删除(可选)
- 删除数据库
shopping
,该操作会删除其位于HDFS
上的shopping
目录。
DROP DATABASE shopping;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-KVUC6lw6-1666829105619)(https://data.educoder.net/api/attachments/279224)]
编程要求
请根据右侧命令行内的提示,在
Begin - End
区域内进行
sql
语句代码补充,具体任务如下:
- 创建数据库
test1
,位于HDFS
的/hive/test1
下,创建人creator
为John
,创建日期date
为2019-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 *********#
版权归原作者 真题OK撒 所有, 如有侵权,请联系我们删除。