键值对信息

添加数据库的描述信息(添加键值对信息)

create database [数据库] with dbproperties('name'='RenZetong','data'='20200101')
--数据所有者:RenZetong 日期:2020-01-01

查看键值对信息

describe database extended [数据库]

修改键值对信息

alter database [数据库] set dbproperties('name'='RenZetong2')

查看更多详细信息

desc database extended [数据库]

数据库的删除操作

drop database [数据库]   #删除一个空的数据库
drop database [数据库] cascade #连同数据库下的表一起删除掉 "强制性删除"

数据库表操作

CREATE [EXTERNAL] TABLE [IF NOT EXISTS] table_name
[(col_name data_type [COMMENT col_comment], ...)]
[COMMENT table_comment]
[PARTITIONED BY (col_name data_type [COMMENT col_comment], ...)]
[CLUSTERED BY (col_name, col_name, ...)
[SORTED BY (col_name [ASC|DESC], ...)] INTO num_buckets BUCKETS]
[ROW FORMAT row_format]
[STORED AS file_format]
[LOCATION hdfs_path]
  • comment 表示注释,默认不能使用中文
  • partitioned by 表示使用表分区,一个表可以拥有多个分区,每一个分区单独存在一个目录下
  • clustered by 对于每一个表分区文件,Hive可以进一步组织成桶,也就是说桶是更为细粒度的数据范围划分。Hive也是针对某一列进行桶的组织
  • sorted by 指定排序字段和排序规则
  • row format 指定表文件字段分隔符
  • stored as 指定表文件的存储格式,常用格式:sequencefile,textfile,rcfile,如果是纯文本文件,可以使用STORED AS TEXTFILE
  • location 指定表文件的存储路径

内部表操作

创建表并指定字段之间的分隔符

create table stu2(id int,name string)
row format
delimited fields
terminated by '/t'; --指定的分隔符

创建表并指定文件的存放路径

create table stu3(id int,name string)
row format
delimited fields
terminated by '\t'
location '/user/stu3'; --指定文件存储路径

根据查询结果来创建表

create table stu3 as select * from stu2;

根据已存在的表结构来创建表

create table stu4 like stu2;

查看表结构

desc stu4;

查看表结构详细信息

desc formatted stu2;

删除表

drop table stu4;

外部表操作

外部表的数据一般是用来共享的,所以删除hive表的时候,数据仍然会存放在hdfs中

分别创建老师和学生的外部表,并向表中添加数据

1、创建老师表

create external table teacher (t_id string,t_name string)
row format
delimited fields terminated by '\t'

2、创建学生表

create external table student(s_id string,s_name string,s_birth string,s_sex string) row format delimited fields terminated by '\t'

将数据加载入表的方式

1、普通加载方式

load data local inpath '/***/***/data.csv' into table ***

2、加载并覆盖方式

load data local inpath '/***/***/data.csv' overwrite into table ***

3、从hdfs文件系统中向表中加载数据(前提是得将数据上传到hdfs系统中)

hdfs dfs -put ***.csv /hivesource
load data inpath '/hivesource/***.csv' into table ***

分区表的操作

在hive中分区就是分文件夹,把大文件切割划分成一个个的小文件,这样每次操作一个小的文件就会很容易了,例如把一个大数据按照每月或者每天进行分割成一个个的小文件,存放在不同的文件夹中.(多分区就是目录的嵌套)

创建一个表带一个分区的语法

create table score(s_id string,c_id string,s_score int)
partitioned by (month string) --指定分区字段
row format
delimited fields
terminated by '\t';

创建一个表带多个分区语法

create table score2(s_id string,c_id string,s_score int)
partitioned by(year string,month string,day string) --指定分区字段
row format
delimited fields
terminated by '\t';

给一个表带一个分区的加载数据

load data local inpath '/root/score.csv' into table score partition(month='20180101');

多分区表加载数据

load data local inpath '/root/score.csv' into table score2
partition(year='2018',month='06',day='01');

分区表查询

select * from score where month = '20180102';

多分区表联合查询(使用union all)

select * from score where month='20180102' union all select * from score where month='20180101';

查看分区

show partitions score;

添加分区

alter table score add partition(month='201805');

删除分区

alter table drop partition(month='201806');

表的修复(建立表与数据文件之间的一个关系映射)

msck repair table ***

分桶表操作

分桶就是MapReduce中的分区。

开启hive的分桶功能

set hive.enforce.bucketing=true;

设置Reduce个数

set mapreduce.job.reduces=3;

创建分桶表

create table course(c_id string,c_name string,t_id string)
clustered by(c_id) into 3 buckets
row format
delimited fields
terminated by '\t';

数据查询

求总行数

select count(*) from table;

求分数的最大值

select max(s_score) from table;

求分数的最小值

select min(s_score) from table;

求分数的总和

select sum(s_score) from table;

求分数的平均值

select avg(s_score) from table;

关系运算

等值比较

select 1 from data_tb where 1=1;

不等值比较

select 1 from data_tb where 1<>2;

小于比较

select 1 from data_tb where 1 < 2;

小于等于比较

select 1 from data_tb where 1 <= 1

大于比较

select 1 from data_tb where 2>1

大于等于比较

select 1 from data_tb where 1 >=1

空值判断

select 1 from data_tb where null is null

非空值判断

select 1 from data_tb where 1 is not null

like比较

select 1 from data_tb where 'footabll' like 'foot%';
select 1 from data_tb where 'footabll' like '%foot%';

like否定比较

select 1 from data_tb where not 'football' like 'foot%';
select 1 from data_tb where not 'football' like '%foot%';

数学运算

加法操作

select 1+9 from data_tb;

减法操作

select 10-5 from data_tb;

乘法操作

select 40*5 from data_tb;

除法操作

select 40/5 from data_tb;

逻辑运算

逻辑与操作:AND

select 1 from data_tb where 1=1 and 2=2;

逻辑或操作:OR

select 1 from data_tb where 1=2 or 2=2;

逻辑非操作:NO

select 1 from data_tb where not 1=2

数值计算

取整函数:round

select round(3.1415925) from data_tb;
> 3
select round(3.5) from data_tb;
> 4

指定精度取整函数:round

select round(3.1415926,4) from data_tb;
> 3.1416

随机数函数:rand

select rand() from data_tb;
> 0.26472837228287
select rand(100) from data_tb;
> 0.72636263627272

绝对值函数:abs

select abs(-3.9) from data_tb;
> 3.9

日期函数

from_unixtime函数将yyyy/mm/dd类型的日期转换为yyyy-mm-dd日期类型

select from_unixtime(unix_timestamp(date,'yyyy/mm/dd'),'yyyy-mm-dd') from date_1;

时间转日期函数:to_date

select to_date('2020-11-12 10:02:11') from data_tb;
> 2020-11-12

日期转年函数:year

select year('2020-11-12 10:22:22') from data_dt;
> 2011

日期转月函数:month

select month('2020-11-12') from data_dt;
> 12

日期转天函数:day

select day('2020-11-12') from data_dt;
> 12

日期转小时函数:hour

select hour('2020-01-02 20:22:12') from data_dt;
> 20

Hive数据库【操作】+ 【分区】+【分桶】+【查询】+【运算】+【函数】的更多相关文章

  1. 【Hive学习之五】Hive 参数&动态分区&分桶

    环境 虚拟机:VMware 10 Linux版本:CentOS-6.5-x86_64 客户端:Xshell4 FTP:Xftp4 jdk8 hadoop-3.1.1 apache-hive-3.1.1 ...

  2. Hive数据库操作

    Hive数据结构 除了基本数据类型(与java类似),hive支持三种集合类型 Hive集合类型数据 array.map.structs hive (default)> create table ...

  3. laravel 数据库操作之 DB facade & 查询构造器 & Eloquent ORM

    <?php namespace App\Http\Controllers; use App\Student; use Illuminate\Support\Facades\DB; class S ...

  4. Spark SQL解析查询parquet格式Hive表获取分区字段和查询条件

    首先说一下,这里解决的问题应用场景: sparksql处理Hive表数据时,判断加载的是否是分区表,以及分区表的字段有哪些?再进一步限制查询分区表必须指定分区? 这里涉及到两种情况:select SQ ...

  5. yii学习笔记(7),数据库操作,联表查询

    在实际开发中,联表查询是很常见的,yii提供联表查询的方式 关系型数据表:一对一关系,一对多关系 实例: 文章表和文章分类表 一个文章对应一个分类 一个分类可以对应多个文章 文章表:article 文 ...

  6. oracle数据库中,分天查询数目

    select to_CHAR(SP_MT_TIME,'DD'),count(*) from table2 group by to_CHAR(SP_MT_TIME,'DD');

  7. HIVE—索引、分区和分桶的区别

    一.索引 简介 Hive支持索引,但是Hive的索引与关系型数据库中的索引并不相同,比如,Hive不支持主键或者外键. Hive索引可以建立在表中的某些列上,以提升一些操作的效率,例如减少MapRed ...

  8. hive -- 分区,分桶(创建,修改,删除)

    hive -- 分区,分桶(创建,修改,删除) 分区: 静态创建分区: 1. 数据: john doe 10000.0 mary smith 8000.0 todd jones 7000.0 boss ...

  9. Hive 的分桶 & Parquet 概念

    分区 & 分桶 都是把数据划分成块.分区是粗粒度的划分,桶是细粒度的划分,这样做为了可以让查询发生在小范围的数据上以提高效率. 分区之后,分区列都成了文件目录,从而查询时定位到文件目录,子数据 ...

  10. 二 Hive分桶

    二.Hive分桶 1.创建分桶表 create table t_buck (id string ,name string) clustered by (id) //根据id分桶 sorted by ( ...

随机推荐

  1. 从SQL Server过渡到PostgreSQL:理解模式的差异

    从SQL Server过渡到PostgreSQL:理解模式的差异 前言 随着越来越多的企业转向开源技术,商业数据库管理员和开发者也逐渐面临向PostgreSQL迁移的需求. 虽然SQL Server和 ...

  2. /sys/kernel/debug/binder/目录下主要节点含义

    /sys/kernel/debug/binder/目录下主要节点含义 state 显示binder设备的整体状态信息 包括进程数量.线程数量.待处理事务数量等 stats 展示binder操作的统计信 ...

  3. USB硬件特性(速度、名称、供电)

    USB传输速度 USB1.0版本,USB LS(Low Speed低速),速度1.5Mbps. USB1.1版本,USB FS(Full Speed全速),速度12Mbps. USB2.0版本,USB ...

  4. ARM64 SMP多核启动(下)- PSCI

    4.支持psci情况 上面说了pin-table的多核启动方式,看似很繁琐,实际上并不复杂,无外乎主处理器唤醒从处理器到指定地址上去执行指令,说他简单是相对于功能来说的,因为他只是实现了从处理器的启动 ...

  5. Linux如何使用trim命令保持SSD的读写速度

    随着硬盘技术的不断发展何固态硬盘的大量使用,你肯定听说过或者使用过固态硬盘,固态硬盘(或固态硬盘)能够达到比传统硬盘更快的读取和写入数据的速度,您可能不知道的是,随着时间的推移,当磁盘写满时,SSD硬 ...

  6. 征服 Docker 镜像访问限制:KubeSphere v3.4.1 成功部署全攻略

    近期,KubeSphere 社区的讨论中频繁出现关于 Docker 官方镜像仓库访问受限的问题. 本文旨在为您提供一个详细的指南, 展示在 Docker 官方镜像访问受限的情况下,如何通过 KubeK ...

  7. 云原生周刊:K8s v1.28 中的结构化身份验证配置

    开源项目推荐 KubeLinter KubeLinter 是一种静态分析工具,用于检查 Kubernetes YAML 文件和 Helm 图表,以确保其中表示的应用程序遵循最佳实践. DB Opera ...

  8. SpringBoot开启Gzip接口报文压缩

    背景 当我们一个接口响应报文比较大的时候,超过几兆甚至几十兆的情况下,减少响应体的报文大小是能有效减少响应时间的. spring boot 配置 server: compression: ## 开启服 ...

  9. CodeQL学习笔记(1)-QL语法(逻辑连接词、量词、聚合词、谓词和类)

    最近在学习CodeQL,对于CodeQL就不介绍了,目前网上一搜一大把.本系列是学习CodeQL的个人学习笔记,根据个人知识库笔记修改整理而来的,分享出来共同学习.个人觉得QL的语法比较反人类,至少与 ...

  10. CSS:Transform属性

    本文将深入探讨css动画中transform属性,这是一种强大的工具,可以实现元素的旋转.缩放.移动和倾斜等效果.本文将通过详细的解释和实际案例,帮助你掌握transform属性的使用方法来增强你的网 ...