【Hive】HQL Map 『CRUD | 相关函数』

文章目录

  • [1. Map 增删改查](#1. Map 增删改查)
    • [1.1 声明 Map 数据类型](#1.1 声明 Map 数据类型)
    • [1.2 增](#1.2 增)
    • [1.3 删](#1.3 删)
    • [1.4 改](#1.4 改)
    • [1.5 查](#1.5 查)
  • [2. Map 相关函数](#2. Map 相关函数)
    • [2.1 单个Map](#2.1 单个Map)
  • [3. Map 与 String](#3. Map 与 String)
    • [3.1 Map 转 string](#3.1 Map 转 string)
    • [3.2 string 转 Map](#3.2 string 转 Map)

1. Map 增删改查

1.1 声明 Map 数据类型

  1. 语法:map<基本数据类型, 基本数据类型> 注意是<>,不是()
  2. 例子:
    1. 创建表时:

      复制代码
      create table temp_db.map_test(
      	id int comment "源数据主键id",
      	smap map<string,string> comment "string型map",
      	imap map<string,int> comment "int型map"
      );
    2. 字段填充时:cast(null as map<string, string>) as XXX

1.2 增

复制代码
insert into temp_db.map_test(id,smap,imap) 
select 12,map('姓名','张三') as pp,map('年龄',23,'性别',1) as dd;

1.3 删

没有删除,只能覆盖

1.4 改

复制代码
array_name['key'] = 'xxxx'

1.5 查

复制代码
select array_name['key'] ;

注意:数组越界会报错。

2. Map 相关函数

2.1 单个Map

  1. map_keys(map_name):获取该map的所有key,结果是一个Array。
  2. map_keys(map_name):获取该map的所有value,结果是一个Array。
  3. size(map_name):获取该map的键值对个数。
  4. 判断map中是否包含某个key值:array_contains(map_keys(map_name), 'key') 或者 map_name["key"] is not null

3. Map 与 String

3.1 Map 转 string

复制代码
select 
    ...,
    concat_ws(',', collect_list(concat_ws(':', k, v) ) )
from test_map_1
lateral view outer explode(map1) kv as k,v

3.2 string 转 Map

复制代码
select str_to_map("name:zhangsan,age:25");

注意:键值对都没有引号

相关推荐
TPBoreas1 天前
springboot3.5比2.x做了哪儿些提升
数据仓库·hive·hadoop
Nefu_lyh2 天前
【Hive】七、Hive 函数:聚合 / 统计 / 分位数 / 集合 / 高级分组
数据仓库·hive·hadoop
KANGBboy2 天前
hive UDF函数
数据仓库·hive·hadoop
王小王-1234 天前
基于商品评价的评论情感分析与可视化系统
hive·情感分析·商品评价分析·主题分析·商品评论分析
Nefu_lyh5 天前
【Hive】 八、Hive 计算引擎:MapReduce / Tez / Spark 对比与选型
hive·spark·mapreduce
白日与明月6 天前
Hive子查询中的ORDER BY陷阱:为什么排序“消失”了?
数据仓库·hive·hadoop
Nefu_lyh7 天前
【Hive】六、Hive 运算逻辑:数学 / 逻辑 / 条件 / 日期 / 字符串函数
数据仓库·hive·hadoop
AQin10128 天前
【对比向】既生瑜何生亮?不!Hive 和 Doris不一样
数据仓库·hive·hadoop·doris
AQin10128 天前
【对比向】细算“成本”——Hive vs. Doris
大数据·数据库·hive·doris·实时数仓
青春万岁!!9 天前
hive分区表加字段后insert字段为空
数据仓库·hive·hadoop