热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

Hive学习之Hive数据库DDL-mysql教程

Hive提供了与SQL相的数据定义语言(DDL),对于熟悉SQL的人来说,学习Hive的DDL是非常容易得,即使从未接触过SQL的人,学习也不是一件很难的事情。虽然本人对SQL有一定的了解,但绝不敢自称熟悉SQL,所以准备对HiveQL进行深入的学习,按照SQL通常的学习曲线,

Hive提供了与SQL相的数据定义语言(DDL),对于熟悉SQL的人来说,学习Hive的DDL是非常容易得,即使从未接触过SQL的人,学习也不是一件很难的事情。虽然本人对SQL有一定的了解,但绝不敢自称熟悉SQL,所以准备对HiveQL进行深入的学习,按照SQL通常的学习曲线,

Hive提供了与SQL相似的数据定义语言(DDL),对于熟悉SQL的人来说,学习Hive的DDL是非常容易得,即使从未接触过SQL的人,学习也不是一件很难的事情。虽然本人对SQL有一定的了解,但绝不敢自称熟悉SQL,所以准备对HiveQL进行深入的学习,按照SQL通常的学习曲线,先学习DDL,再学习DML(数据操作语言)。由于需要演示一些语句的示例,不得不超前使用一些其它语句,比如show、describe等。

Create/Drop/Alter数据库

创建数据库的语法如下:

CREATE(DATABASE|SCHEMA) [IF NOT EXISTS] database_name
[COMMENTdatabase_comment]
[LOCATIONhdfs_path]
[WITHDBPROPERTIES (property_name=property_value, ...)];

在创建数据库时可以指定数据库在HDFS上的存储位置以及数据库的属性,示例如下:

hive> showdatabases;
OK
default
Time taken:1.842 seconds, Fetched: 1 row(s)
hive> createdatabase learning comment 'Learning Hive Database' withdbproperties('creator'='hadoop','date'='2014-06-04', 'test'='First database');
OK
Time taken:5.274 seconds
hive> showdatabases;
OK
default
learning
Time taken:0.022 seconds, Fetched: 2 row(s)
hive>describe database learning;
OK
learning Learning Hive Database   hdfs://hadoop:9000/user/hive/warehouse/learning.db hadoop
Time taken:0.078 seconds, Fetched: 1 row(s)

从例子的演示来看,默认情况下新建的数据库存储在/user/hive/warehouse,该值可由hive.metastore.warehouse.dir参数指定,默认即为上述目录,数据库的拥有者为hadoop用户,可以使用下面即将介绍的alter语句修改数据库的拥有者为hive:

hive> alterdatabase learning set owner user hive;
OK
Time taken:0.255 seconds
hive>describe database learning;
OK
learning Learning Hive Database   hdfs://hadoop:9000/user/hive/warehouse/learning.db hive
Time taken:0.015 seconds, Fetched: 1 row(s)

Drop数据库的语法如下:

DROP (DATABASE|SCHEMA) [IF EXISTS] database_name [RESTRICT|CASCADE];
hive> drop database learning;
OK
Time taken: 0.933 seconds
hive> show databases;
OK
default
Time taken: 0.037 seconds, Fetched: 1 row(s)
hive> dfs -lsr /user/hive/warehouse;
drwxr-xr-x   - hadoopsupergroup          0 2014-05-23 16:43/user/hive/warehouse/page_view
drwxr-xr-x   - hadoopsupergroup          0 2014-05-14 11:29/user/hive/warehouse/pokes

从上面的输出结果可以看出,在数据库中不存在表的情况下可以直接删除数据库,那么如果数据库存在表结果会是如何呢?下面的例子演示了这种情况:

hive> use learning;
OK
Time taken: 0.105 seconds hive> create table how(name string);
OK
Time taken: 0.982 seconds
hive> dfs -lsr /user/hive/warehouse;
drwxr-xr-x   - hadoopsupergroup          0 2014-06-04 11:11/user/hive/warehouse/learning.db
drwxr-xr-x   - hadoopsupergroup          0 2014-06-04 11:11/user/hive/warehouse/learning.db/how
drwxr-xr-x   - hadoopsupergroup          0 2014-05-23 16:43/user/hive/warehouse/page_view
drwxr-xr-x   - hadoopsupergroup          0 2014-05-14 11:29/user/hive/warehouse/pokes
hive> drop database learning;
FAILED: Execution Error, return code 1 fromorg.apache.hadoop.hive.ql.exec.DDLTask.InvalidOperationException(message:Database learning is not empty. One or moretables exist.)
hive> drop database learning restrict;
FAILED: Execution Error, return code 1 fromorg.apache.hadoop.hive.ql.exec.DDLTask.InvalidOperationException(message:Database learning is not empty. One or moretables exist.)
hive> drop database learning cascade;
OK
Time taken: 3.151 seconds
hive> show databases;
OK
default
Time taken: 0.019 seconds, Fetched: 1 row(s)
hive> dfs -lsr /user/hive/warehouse;
drwxr-xr-x   - hadoopsupergroup          0 2014-05-23 16:43/user/hive/warehouse/page_view
drwxr-xr-x   - hadoopsupergroup          0 2014-05-14 11:29/user/hive/warehouse/pokes

当数据库中存在表时无法直接删除,会提示数据库非空,存在表,这时可以使用CASCADE关键字,使用RESTRICT关键字与默认行为等价。

Alter数据库的语法如下:

ALTER DATABASEdatabase_name SET DBPROPERTIES (property_name=property_value, ...);
ALTER DATABASEdatabase_name SET OWNER [USER|ROLE] user_or_role;

推荐阅读
  • 本文详细分析了Hive在启动过程中遇到的权限拒绝错误,并提供了多种解决方案,包括调整文件权限、用户组设置以及环境变量配置等。 ... [详细]
  • Hadoop入门与核心组件详解
    本文详细介绍了Hadoop的基础知识及其核心组件,包括HDFS、MapReduce和YARN。通过本文,读者可以全面了解Hadoop的生态系统及应用场景。 ... [详细]
  • Hadoop发行版本选择指南:技术解析与应用实践
    本文详细介绍了Hadoop的不同发行版本及其特点,帮助读者根据实际需求选择最合适的Hadoop版本。内容涵盖Apache Hadoop、Cloudera CDH等主流版本的特性及应用场景。 ... [详细]
  • 本文探讨了如何在Hive(基于Hadoop)环境中编写类似SQL的语句,以去除字段中的空格。特别是在处理邮政编码等数据时,去除特定位置的空格是常见的需求。 ... [详细]
  • 本文详细介绍如何使用 Apache Spark 执行基本任务,包括启动 Spark Shell、运行示例程序以及编写简单的 WordCount 程序。同时提供了参数配置的注意事项和优化建议。 ... [详细]
  • 本文介绍了Hive作为基于Hadoop的数据仓库工具的核心概念,包括其基本功能、使用理由、特点以及与Hadoop的关系。同时,文章还探讨了Hive相较于传统关系型数据库的不同之处,并展望了Hive的发展前景。 ... [详细]
  • HBase运维工具全解析
    本文深入探讨了HBase常用的运维工具,详细介绍了每种工具的功能、使用场景及操作示例。对于HBase的开发人员和运维工程师来说,这些工具是日常管理和故障排查的重要手段。 ... [详细]
  • 本文详细介绍了 Flink 和 YARN 的交互机制。YARN 是 Hadoop 生态系统中的资源管理组件,类似于 Spark on YARN 的配置方式。我们将基于官方文档,深入探讨如何在 YARN 上部署和运行 Flink 任务。 ... [详细]
  • 本文详细探讨了 org.apache.hadoop.ha.HAServiceTarget 类中的 checkFencingConfigured 方法,包括其功能、应用场景及代码示例。通过实际代码片段,帮助开发者更好地理解和使用该方法。 ... [详细]
  • 简化报表生成:EasyReport工具的全面解析
    本文详细介绍了EasyReport,一个易于使用的开源Web报表工具。该工具支持Hadoop、HBase及多种关系型数据库,能够将SQL查询结果转换为HTML表格,并提供Excel导出、图表显示和表头冻结等功能。 ... [详细]
  • 深入解析Hadoop的核心组件与工作原理
    本文详细介绍了Hadoop的三大核心组件:分布式文件系统HDFS、资源管理器YARN和分布式计算框架MapReduce。通过分析这些组件的工作机制,帮助读者更好地理解Hadoop的架构及其在大数据处理中的应用。 ... [详细]
  • 本文探讨了Hive作业中Map任务数量的确定方式,主要涉及HiveInputFormat和CombineHiveInputFormat两种InputFormat的分片计算逻辑。通过调整相关参数,可以有效控制Map任务的数量,进而优化Hive作业的性能。 ... [详细]
  • 深入解析BookKeeper的设计与应用场景
    本文介绍了由Yahoo在2009年开发并于2011年开源的BookKeeper技术。BookKeeper是一种高效且可靠的日志流存储解决方案,广泛应用于需要高性能和强数据持久性的场景。 ... [详细]
  • 本文详细记录了一次 HBase RegionServer 异常宕机的情况,包括具体的错误信息和可能的原因分析。通过此案例,探讨了如何有效诊断并解决 HBase 中常见的 RegionServer 挂起问题。 ... [详细]
  • 大数据SQL优化:全面解析数据倾斜解决方案
    本文深入探讨了大数据SQL优化中的数据倾斜问题,提供了多种解决策略和实际案例,旨在帮助读者理解和应对这一常见挑战。 ... [详细]
author-avatar
mobiledu2502886187
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有