文章目录
- 前言
- 一、数据库操作
-
- [1. 创建数据库](#1. 创建数据库)
-
- [1.1 语法及解释](#1.1 语法及解释)
- [1.2 创建数据库示例](#1.2 创建数据库示例)
- [2. 查看数据库](#2. 查看数据库)
-
- [2.1 查看所有数据库](#2.1 查看所有数据库)
- [2.2 查看数据库信息](#2.2 查看数据库信息)
-
- [2.2.1 语法及解释](#2.2.1 语法及解释)
- [2.2.2 查看数据库信息示例](#2.2.2 查看数据库信息示例)
- [3. 切换数据库](#3. 切换数据库)
-
- [3.1 语法](#3.1 语法)
- [3.2 示例](#3.2 示例)
- [4. 修改数据库](#4. 修改数据库)
-
- [4.1 语法](#4.1 语法)
- [4.2 示例](#4.2 示例)
- [5. 删除数据库](#5. 删除数据库)
-
- [5.1 语法及解释](#5.1 语法及解释)
- [5.2 示例](#5.2 示例)
- 注意
前言
本指南旨在提供一份全面而详细的 Hive 数据库操作手册,帮助读者深入理解并熟练运用 Hive 中的数据库管理命令。我们将从最基础的创建数据库开始,逐步介绍如何查看现有数据库及其信息、切换当前使用的数据库、修改数据库属性及位置,直到最后讲解如何删除不再需要的数据库。
一、数据库操作
1. 创建数据库
1.1 语法及解释
创建数据库的语法如下:
sql
CREATE (DATABASE|SCHEMA) [IF NOT EXISTS] database_name
[COMMENT database_comment]
[LOCATION hdfs_path]
[WITH DBPROPERTIES (property_name=property_value, ...)];
语法解释:
(DATABASE|SCHEMA)
:指定要创建的对象类型。SCHEMA 和 DATABASE 的用法是可以互换的,它们的含义是一样的。[IF NOT EXISTS]
:这是一个可选的子句,确保只有在指定的数据库或模式不存在时才进行创建。[COMMENT database_comment]
:这是一个可选的参数,用于提供关于数据库或模式的注释或描述。[LOCATION hdfs_path]
:这是一个可选的参数,用于指定数据库或模式在HDFS(分布式文件系统)中的位置。[WITH DBPROPERTIES (property_name=property_value, ...)]
:这是一个可选的参数,用于指定数据库或模式的属性。可以自定义多个属性,每个属性由属性名和属性值组成。
1.2 创建数据库示例
创建数据库ods_test01
。
sql
create database if not exists ods_test01
comment '创建测试数据库示例'
location '/user/hive/location/ods_test01'
with dbproperties ('creator'= 'handsome','create_time'='2024-12-13 21:34:35');
创建数据库ods_test02
。
sql
create database if not exists ods_test02;
创建数据库
ods_test01
后自定义的/user/hive/location/ods_test01
目录会自动创建。创建数据库
ods_test02
没有指定location属性,默认会保存到配置文件hive-site.xml
中设置的hive在HDFS上的默认目录/user/hive/warehouse
下,默认名称为数据库名称.db
此处为ods_test02.db
。
在这个创建数据库的示例中,数据库ods_test01
对应hdfs上的/user/hive/location/ods_test01
目录,也就是说数据库ods_test01
中的表和数据若没有特殊指定位置,都将保存在/user/hive/location/ods_test01
目录下。
可以使用如下命令查看数据库ods_test01
的目录。
可以使用如下命令查看数据库ods_test02
的目录。
或者可以访问hdfs的UI页面查看数据库ods_test01
和数据库ods_test02
的目录。
2. 查看数据库
2.1 查看所有数据库
sql
show databases;
2.2 查看数据库信息
2.2.1 语法及解释
查看数据库信息语法如下。
sql
DESCRIBE DATABASE [EXTENDED] database_name;
语法解释:
- EXTENDED:显示更详细的信息(数据库属性信息)。
2.2.2 查看数据库信息示例
查看数据库ods_test01
和数据库ods_test02
的信息。
sql
describe database ods_test01;
describe database ods_test02;
查看数据库ods_test01
和数据库ods_test02
的信息及数据库属性信息。
sql
describe database extended ods_test01;
describe database extended ods_test02;
3. 切换数据库
3.1 语法
切换数据库的语法如下。
sql
USE database_name;
3.2 示例
切换到数据库ods_test01
。
sql
use ods_test01;
4. 修改数据库
4.1 语法
修改数据库属性语法如下。
sql
ALTER (DATABASE|SCHEMA) database_name SET DBPROPERTIES (property_name=property_value, ...);
修改数据库所属用户语法如下。
sql
ALTER (DATABASE|SCHEMA) database_name SET OWNER [USER|ROLE] user_or_role;
修改数据库位置语法如下。
sql
ALTER (DATABASE|SCHEMA) database_name SET LOCATION hdfs_path;
4.2 示例
修改数据库ods_test01
属性示例。
sql
alter database ods_test01 set dbproperties ('creator'= 'alter_handsome','new_pro'='alter_test');
查看数据库ods_test01
修改后的属性。
sql
describe database extended ods_test01;
修改数据库ods_test01
所属用户示例。
sql
alter database ods_test01 set owner user test_user;
查看数据库ods_test01
修改后的用户。
sql
describe database ods_test01;
修改数据库ods_test01
的位置示例。
sql
alter database ods_test01 set location 'hdfs://hadoop:9000/user/hive/new_location/ods_test01.db';
在 Hive 中,修改数据库的位置时,实际上只更新了MySQL中元数据存储的位置信息,并不会自动移动 HDFS 上的数据。这意味着旧位置的数据仍然保留在原来的 HDFS 路径中,而新的路径将被用作未来操作的默认位置。也就是说修改数据库的位置后,并不会改变创建数据库时设置的数据库位置,而是在元数据中把新位置映射到原位置。
查看数据库ods_test01
修改后的位置。
sql
describe database ods_test01;
5. 删除数据库
5.1 语法及解释
删除数据库语法如下。
sql
DROP (DATABASE|SCHEMA) [IF EXISTS] database_name [RESTRICT|CASCADE];
语法解释:
[RESTRICT|CASCADE]
:这是一个可选的子句,用于指定删除操作的级联行为。如果使用RESTRICT
,则只有在数据库或模式为空(没有表或其他对象)时才允许删除。如果使用CASCADE
,则会删除数据库或模式以及其中的所有对象。默认使用RESTRICT
。
5.2 示例
删除空数据库ods_test02
。
sql
drop database if exists ods_test02;
删除不为空的数据库ods_test01
。
sql
drop database if exists ods_test01 cascade;
注意
删除数据库后,hdfs上对应的数据库目录和MySQL中数据库对应的元数据会一起删除;所以对于数据库的删除不能直接删除删除hdfs上对应的目录。