问题导读:
1、创建数据库命令中DATABASE可以被哪个关键字代替使用?
4、删除数据库命令中CASCADE的作用,默认值是?
5、数据库修改操作只能修改数据哪两方面信息?
一、创建数据库
CREATE (DATABASE|SCHEMA) [IF NOT EXISTS] database_name
[COMMENT database_comment]
[LOCATION hdfs_path]
[WITH DBPROPERTIES (property_name=property_value, ...)];
如上,是创建Hive数据库的一般模型,其中,DATABASE和SCHEMA表示同一个意思,所有数据库相关的命令中,都可以使用SCHEMA关键字代替DATABASE,如“CREATE DATABASE test” 和“CREATE SCHEMA test ”都表示创建test数据库。
COMMENT:对数据库添加一些描述性信息;
LOCATION:指定数据库存放路径。默认是根据Hive-site.xml如下配置路径后面目录中创建以.db结尾的数据库目录。
<property>
<name>hive.metastore.warehouse.dir</name>
<value>hdfs://secondmgt:8020/hive/warehouse</value>
</property>
WITH DBPROPERTIES:为数据库增加一些和其相关的键-值对属性信息。
hive> CREATE DATABASE test
> COMMENT 'Test database is used for exercise'
> LOCATION '/input'
> WITH DBPROPERTIES ('creator'='NIITYZU','data'='2015-01-06');
OK
Time taken: 0.07 seconds
hive> DESCRIBE DATABASE EXTENDED test;
OK
test Test database is used for exercise hdfs://secondmgt:8020/input/testdb hadoopUser
Time taken: 0.018 seconds, Fetched: 1 row(s)
二、显示数据库
SHOW (DATABASES|SCHEMAS) [LIKE identifier_with_wildcards];
事例操作如下:
hive> SHOW DATABASES;
OK
default
hive
test
Time taken: 0.013 seconds, Fetched: 3 row(s)
hive> SHOW DATABASES LIKE 't.*';
OK
test
Time taken: 0.033 seconds, Fetched: 1 row(s)
三、删除数据库
DROP (DATABASE|SCHEMA) [IF EXISTS] database_name [RESTRICT|CASCADE];
IF EXISTS是可选的,默认情况下,Hive是不允许用户删除一个包含有表的数据库的。用户要么先删除数据库中所有的表,再删除数据库;要么在删除数据语句后面加上关键字CASCADE,使Hive先自行删除数据库中的表,默认情况下后面接的是RESTRICT(可以不加)。否则会报以下错误:
hive> DROP DATABASE test;
FAILED: Execution Error, return code 1 from org.apache.hadoop.hive.ql.exec.DDLTask. InvalidOperationException(message:Database test is not empty. One or more tables exist.)
加上CASCADE后,数据库可以正常删除,并且其对应的目录也同时被删除。
hive> DROP DATABASE test CASCADE;
OK
Time taken: 0.607 seconds
四、修改数据库
用户可以使用ALTER DATABASE命令为某个数据库的DBPROPERTIES设置键-值对属性值,来描述这个数据库的属性信息;也可以使用该命令修改数据库的用户或权限,但是数据库的其他元数据信息都是不可以更改的,包括数据库名和数据库所在的目录位置。一般模式如下:
ALTER (DATABASE|SCHEMA) database_name SET DBPROPERTIES (property_name=property_value, ...);
ALTER (DATABASE|SCHEMA) database_name SET OWNER [USER|ROLE] user_or_role;
此处不详细介绍修改功能。