当前位置: 首页> 游戏> 手游 > 峡江网站建设_广告设计公司前台_线上宣传渠道和宣传方式_百度投诉中心电话24个小时

峡江网站建设_广告设计公司前台_线上宣传渠道和宣传方式_百度投诉中心电话24个小时

时间:2025/7/9 12:18:55来源:https://blog.csdn.net/zcs2312852665/article/details/144460186 浏览次数:0次
峡江网站建设_广告设计公司前台_线上宣传渠道和宣传方式_百度投诉中心电话24个小时

文章目录

  • 前言
  • 一、数据库操作
    • 1. 创建数据库
      • 1.1 语法及解释
      • 1.2 创建数据库示例
    • 2. 查看数据库
      • 2.1 查看所有数据库
      • 2.2 查看数据库信息
        • 2.2.1 语法及解释
        • 2.2.2 查看数据库信息示例
    • 3. 切换数据库
      • 3.1 语法
      • 3.2 示例
    • 4. 修改数据库
      • 4.1 语法
      • 4.2 示例
    • 5. 删除数据库
      • 5.1 语法及解释
      • 5.2 示例
  • 注意


前言

本指南旨在提供一份全面而详细的 Hive 数据库操作手册,帮助读者深入理解并熟练运用 Hive 中的数据库管理命令。我们将从最基础的创建数据库开始,逐步介绍如何查看现有数据库及其信息、切换当前使用的数据库、修改数据库属性及位置,直到最后讲解如何删除不再需要的数据库。


一、数据库操作

1. 创建数据库

1.1 语法及解释

创建数据库的语法如下:

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

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

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 查看所有数据库

show databases;

在这里插入图片描述

2.2 查看数据库信息

2.2.1 语法及解释

查看数据库信息语法如下。

DESCRIBE DATABASE [EXTENDED] database_name;

语法解释:

  • EXTENDED:显示更详细的信息(数据库属性信息)。
2.2.2 查看数据库信息示例

查看数据库ods_test01和数据库ods_test02的信息。

describe database ods_test01;
describe database ods_test02;

在这里插入图片描述
查看数据库ods_test01和数据库ods_test02的信息及数据库属性信息。

describe database extended ods_test01;
describe database extended ods_test02;

在这里插入图片描述

3. 切换数据库

3.1 语法

切换数据库的语法如下。

USE database_name;

3.2 示例

切换到数据库ods_test01

use ods_test01;

在这里插入图片描述

4. 修改数据库

4.1 语法

修改数据库属性语法如下。

ALTER (DATABASE|SCHEMA) database_name SET DBPROPERTIES (property_name=property_value, ...);

修改数据库所属用户语法如下。

ALTER (DATABASE|SCHEMA) database_name SET OWNER [USER|ROLE] user_or_role;

修改数据库位置语法如下。

ALTER (DATABASE|SCHEMA) database_name SET LOCATION hdfs_path;

4.2 示例

修改数据库ods_test01属性示例。

alter database ods_test01 set dbproperties  ('creator'= 'alter_handsome','new_pro'='alter_test');

查看数据库ods_test01修改后的属性。

describe database extended ods_test01;

在这里插入图片描述

修改数据库ods_test01所属用户示例。

alter database ods_test01 set owner user test_user;

查看数据库ods_test01修改后的用户。

describe database ods_test01;

在这里插入图片描述

修改数据库ods_test01的位置示例。

alter database ods_test01 set location 'hdfs://hadoop:9000/user/hive/new_location/ods_test01.db';

在 Hive 中,修改数据库的位置时,实际上只更新了MySQL中元数据存储的位置信息,并不会自动移动 HDFS 上的数据。这意味着旧位置的数据仍然保留在原来的 HDFS 路径中,而新的路径将被用作未来操作的默认位置。也就是说修改数据库的位置后,并不会改变创建数据库时设置的数据库位置,而是在元数据中把新位置映射到原位置。

查看数据库ods_test01修改后的位置。

describe database ods_test01;

在这里插入图片描述

5. 删除数据库

5.1 语法及解释

删除数据库语法如下。

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

语法解释:

  • [RESTRICT|CASCADE]:这是一个可选的子句,用于指定删除操作的级联行为。如果使用RESTRICT,则只有在数据库或模式为空(没有表或其他对象)时才允许删除。如果使用CASCADE,则会删除数据库或模式以及其中的所有对象。默认使用RESTRICT

5.2 示例

删除空数据库ods_test02

drop database if exists ods_test02;

在这里插入图片描述
删除不为空的数据库ods_test01

drop database if exists ods_test01 cascade;

在这里插入图片描述

注意

删除数据库后,hdfs上对应的数据库目录和MySQL中数据库对应的元数据会一起删除;所以对于数据库的删除不能直接删除删除hdfs上对应的目录。

关键字:峡江网站建设_广告设计公司前台_线上宣传渠道和宣传方式_百度投诉中心电话24个小时

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

责任编辑: