首页 > 其他分享 >hive学习笔记之二:复杂数据类型

hive学习笔记之二:复杂数据类型

时间:2024-09-23 13:22:08浏览次数:14  
标签:address 数据类型 t3 hive 之二 person tom select row

select person, friends[0], friends[3] from t2;

执行结果如下,第一条记录没有friends[3],显示为NULL:

hive> select person, friends[0], friends[3] from t2;

OK

person _c1 _c2

tom tom_friend_0 NULL

jerry jerry_friend_0 jerry_friend_3

Time taken: 0.052 seconds, Fetched: 2 row(s)

  1. 数组元素中是否包含某值的SQL:

select person, array_contains(friends, 'tom_friend_0') from t2;

执行结果如下,第一条记录friends数组中有tom_friend_0,显示为true,第二条记录不包含,就显示false:

hive> select person, array_contains(friends, 'tom_friend_0') from t2;

OK

person _c1

tom true

jerry false

Time taken: 0.061 seconds, Fetched: 2 row(s)

  1. 第一条记录的friends数组中有三个元素,借助LATERAL VIEW语法可以把这三个元素拆成三行,SQL如下:

select t.person, single_friend

from (

select person, friends

from t2 where person='tom'

) t LATERAL VIEW explode(t.friends) v as single_friend;

执行结果如下,可见数组中的每个元素都能拆成单独一行:

OK

t.person single_friend

tom tom_friend_

tom tom_friend_1

tom tom_friend_2

Time taken: 0.058 seconds, Fetched: 3 row(s)

  • 以上就是数组的基本操作,接下来是键值对;

MAP,建表,导入数据

  • 接下来打算创建名为t3的表,只有person和address两个字段,person是字符串类型,address是MAP类型,通过文本文件导入数据时,对分隔符的定义如下:
  1. person和address之间的分隔符是竖线;

  2. address内部有多个键值对,它们的分隔符是逗号;

  3. 而每个键值对的键和值的分隔符是冒号;

  • 满足上述要求的建表语句如下所示:

create table if not exists t3(

person string,

address map<string, string>

)

row format delimited

fields terminated by '|'

collection items terminated by ','

map keys terminated by ':';

  • 创建文本文件003.txt,可见用了三种分隔符来分隔字段、MAP中的多个元素、每个元素键和值:

tom|province:guangdong,city:shenzhen

jerry|province:jiangsu,city:nanjing

  • 导入003.txt的数据到t3表:

load data local inpath '/home/hadoop/temp/202010/25/003.txt' into table t3;

MAP,查询

  1. 查看全部数据:

hive> select * from t3;

OK

t3.person t3.address

tom {"province":"guangdong","city":"shenzhen"}

jerry {"province":"jiangsu","city":"nanjing"}

Time taken: 0.075 seconds, Fetched: 2 row(s)

  1. 查看MAP中的某个key,语法是field[“xxx”]:

hive> select person, address["province"] from t3;

OK

person _c1

tom guangdong

jerry jiangsu

Time taken: 0.075 seconds, Fetched: 2 row(s)

  1. 使用if函数,下面的SQL是判断address字段中是否有"street"键,如果有就显示对应的值,没有就显示filed street not exists:

select person,

if(address['street'] is null, "filed street not exists", address['street'])

from t3;

输出如下,由于address字段只有province和city两个键,因此会显示filed street not exists:

OK

tom filed street not exists

jerry filed street not exists

Time taken: 0.087 seconds, Fetched: 2 row(s)

  1. 使用explode将address字段的每个键值对展示成一行:

hive> select explode(address) from t3;

OK

province guangdong

city shenzhen

province jiangsu

city nanjing

Time taken: 0.081 seconds, Fetched: 4 row(s)

  1. 上面的explode函数只能展示address字段,如果还要展示其他字段就要继续LATERAL VIEW语法,如下,可见前面的数组展开为一个字段,MAP展开为两个字段,分别是key和value:

select t.person, address_key, address_value

from (

select person, address

from t3 where person='tom'

) t LATERAL VIEW explode(t.address) v as address_key, address_value;

结果如下:

OK

tom province guangdong

tom city shenzhen

Time taken: 0.118 seconds, Fetched: 2 row(s)

  1. size函数可以查看MAP中键值对的数量:

hive> select person, size(address) from t3;

OK

tom 2

jerry 2

Time taken: 0.082 seconds, Fetched: 2 row(s)

STRUCT

  1. STRUCT是一种记录类型,它封装了一个命名的字段集合,里面有很多属性,新建名为t4的表,其info字段就是STRUCT类型,里面有age和city两个属性,person和info之间的分隔符是竖线,info内部的多个元素之间的分隔符是逗号,注意声明分隔符的语法:

create table if not exists t4(

person string,

info struct<age:int, city:string>

)

row format delimited

fields terminated by '|'

collection items terminated by ',';

  1. 准备好名为004.txt的文本文件,内容如下:

tom|11,shenzhen

jerry|12

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎徽关注公zhong号:编程进阶路 加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

,nanjing

  1. 加载004.txt的数据到t4表:

load data local inpath '/home/hadoop/temp/202010/25/004.txt' into table t4;

  1. 查看t4的所有数据:

hive> select * from t4;

OK

tom {"age":11,"city":"shenzhen"}

jerry {"age":12,"city":"nanjing"}

Time taken: 0.063 seconds, Fetched: 2 row(s)

  1. 查看指定字段,用filedname.xxx语法:

hive> select person, info.city from t4;

OK

tom shenzhen

jerry nanjing

Time taken: 0.141 seconds, Fetched: 2 row(s)

UNION

  • 最后一种是UNIONTYPE,这是从几种数据类型中指明选择一种,由于UNIONTYPE数据的创建设计到UDF(create_union),这里先不展开了,先看看建表语句:

CREATE TABLE union_test(foo UNIONTYPE<int, double, array<string>, struct<a:int,b:string>>);

标签:address,数据类型,t3,hive,之二,person,tom,select,row
From: https://blog.51cto.com/u_17015016/12088827

相关文章

  • D15【python接口自动化学习】-python基础之内置数据类型
    day15字典的常见操作(上)学习日期:20240922学习目标:内置数据类型--24常见常新:字典的常见操作(上)学习笔记:字典的内置函数访问字典的内容#访问字典的所有元素mail_list={'tom':'tom@gmail.com','jerry':'jerry@foxmail.com','john':'john@163.com'}print(mail_li......
  • PostgreSQL向量数据类型SQL示例
    PostgreSQL支持多种数据类型,其中包括向量类型,可以用来存储和处理几何对象,如点(points)、线(lines)、线段(linesegments)、盒子(boxes)、圆(circles)、路径(paths)、多边形(polygons)等。此外,PostgreSQL还支持数组类型,可以用来存储一维或多维数组。向量数据类型示例1.几何类型PostgreSQL提供......
  • Java 入门基础篇08 - Java的变量与数据类型的认识
    1.变量概述什么是变量在程序运行的过程中其值可以在某个范围改变的量变量的作用在程序运行过程中存放某一个不断发生改变的值,在运行时JVM会为变量分配一块内存空间如何定义变量数据类型变量名=变量值;在java中定义变量时必须指定数据类型1. 数据类型数据类型概述......
  • Hive企业级调优[7]——HQL语法优化之小文件合并
    目录HQL语法优化之小文件合并 优化说明 Map端输入文件合并Reduce端输出文件合并优化案例HQL语法优化之小文件合并 优化说明小文件合并优化主要分为两个方面:Map端输入的小文件合并以及Reduce端输出的小文件合并。 Map端输入文件合并合并Map端输入的小文件意味着......
  • Hive企业级调优[8]—— 其他优化
    目录 其他优化CBO优化 优化说明 优化案例 谓词下推 优化说明 优化案例 矢量化查询Fetch抓取 本地模式优化说明 优化案例并行执行 严格模式 其他优化CBO优化 优化说明CBO(CostBasedOptimizer),即基于成本的优化。在Hive中,成本模型考虑到了数据的......
  • JavaScript数据类型转换 字符串
    类型转换数据类型的转换有两种方式,一种是在运算等处理过程中自动转换,另一种是显式的转换。字符串类型转换除了在处理过程中的隐式转换,可以使用String(Value)函数进行转换。例子1:letval1=true;letval2=false;letval3=null;letval4=99;letval5=798.125; console.log(......
  • QT字符串类应用与常用数据类型:
    写在开头:我们可以去这个网站进行学习C++的相关知识:https://github.com/0voice目录1、Qt字符串类应用(1)操作字符串的方式(2)查询字符串的方式:2、Qt常见基本数据类型(注意:定义在#include)总结:1、Qt字符串类应用(1)操作字符串的方式第一:QString提供一个二元的“+”操作......
  • D13【python接口自动化学习】-python基础之内置数据类型
    day13集合学习日期:20240920学习目标:内置数据类型--22常见常新:集合的常见操作学习笔记:集合与set对象创建set对象set对象的常用操作#使用set对象对元组去重color=('r','g','b','g','b','b')#创建元组new_color=set(color)#转换set对象去重print(new_color)#......