Apache Doris map_filter 用法

适用版本:Doris 2.1.0+(正式支持 Map + Lambda 高阶函数)

一、基础语法

两种合法入参顺序(都能执行,推荐第一种标准写法)

sql

复制代码
-- 标准写法(推荐:集合在前,Lambda 在后)
map_filter(map_expr, (k, v) -> boolean_condition)

-- 兼容写法(Lambda 在前,集合在后,不推荐)
map_filter((k, v) -> boolean_condition, map_expr)

参数说明

  1. map_expr 待过滤的 Map 类型字段 / 表达式,可为列、map() 常量、map_keys() 结果等。
  2. Lambda 表达式 (k, v) -> 布尔条件
    • k:遍历中当前键(key)
    • v:遍历中当前值(value)
    • 表达式最终必须返回 布尔值true/false
  3. 返回值Map,仅保留 Lambda 结果为 true 的键值对;无匹配项返回空 Map;原 Map 为 NULL 则返回 NULL

二、准备测试表 & 数据

sql

复制代码
CREATE TABLE test_map_demo (
    id INT,
    info Map<String, INT>
) DUPLICATE KEY(id)
DISTRIBUTED BY HASH(id) BUCKETS 1;

INSERT INTO test_map_demo VALUES
(1, map('a', 10, 'b', 20, 'c', 30)),
(2, map('x', 5, 'y', 15)),
(3, map('k1', NULL, 'k2', 100)),
(4, map()); -- 空Map

三、常用示例

1. 按 value 过滤(最常用)

保留 value 大于 10 的键值对

sql

复制代码
SELECT
    id,
    info,
    map_filter(info, (k, v) -> v > 10) AS res_map
FROM test_map_demo;

2. 按 key 过滤

只保留 key 为 by 的数据

sql

复制代码
SELECT
    id,
    map_filter(info, (k, v) -> k IN ('b', 'y')) AS res_map
FROM test_map_demo;

3. key + value 组合条件

sql

复制代码
SELECT
    id,
    map_filter(info, (k, v) -> k != 'a' AND v < 30) AS res_map
FROM test_map_demo;

4. 过滤 NULL 值

剔除 value 为 NULL 的键值对

sql

复制代码
SELECT
    id,
    map_filter(info, (k, v) -> v IS NOT NULL) AS res_map
FROM test_map_demo WHERE id = 3;

5. 结合数组函数(你的业务场景)

判断 key 存在于指定数组中,实现Map 交集过滤

sql

复制代码
-- 保留 pre.index_map 中 key 同时存在于 dy_0.index_map 的键值对
SELECT
map_filter(
    pre.index_map,
    (k, v) -> array_contains( coalesce(map_keys(dy_0.index_map), []), k )
) AS result_map
FROM pre, dy_0;

四、搭配常用函数

  1. map_filter + map_size:统计过滤后键值对数量

sql

复制代码
SELECT
    id,
    map_size(map_filter(info, (k, v) -> v > 10)) AS cnt
FROM test_map_demo;
  1. map_filter + explode_map:过滤后拆分成行

sql

复制代码
SELECT
    id, k, v
FROM test_map_demo
LATERAL VIEW explode_map( map_filter(info, (k, v) -> v > 10) ) t AS k, v;
  1. coalesce 兜底 :防止 Map 为 NULL 报错

sql

复制代码
map_filter( coalesce(info, map()), (k, v) -> v > 10 )

五、核心注意事项

  1. 版本限制 2.1.0 以下版本不支持 Lambda + map_filter,会报语法错误。

  2. Lambda 格式硬性要求

    • 必须写两个参数 (k, v),不能只写一个;
    • 箭头 -> 符号不能写错。
  3. 类型匹配 条件里对 k/v 的运算,类型要和原 Map 定义一致,避免类型报错。

  4. 两种入参顺序说明 Doris 兼容 (Map, Lambda)(Lambda, Map) 两种写法,都不报错;统一使用 Map 在前 标准写法,可读性和兼容性更好

  5. array_filter 区分(快速记忆)

    • array_filter:处理数组,Lambda 单参数 x -> 条件,返回数组
    • map_filter:处理 Map,Lambda 双参数 (k,v) -> 条件,返回 Map

六、最简模板(直接套用)

sql

复制代码
-- 通用模板
map_filter( Map字段, (k, v) -> 过滤条件 )
相关推荐
云絮.2 小时前
数据库约束
java·数据库·sql·mysql·oracle
Theo·Chan17 小时前
机房断电搞崩服务器 | 人大金仓 V8 全量备份跨实例完整恢复实录
sql·信创·kingbase·金仓
持敬chijing20 小时前
Web渗透之SQL注入总结
sql·安全·web安全·网络安全·网络攻击模型·web
davawang20 小时前
基于SQL实现分组的文字排序聚合
sql·分析函数·数据平台
可乐ea1 天前
【Spring Boot + MyBatis|第4篇】MyBatis 动态 SQL:if、where、foreach 使用详解
java·spring boot·后端·sql·mybatis
IvorySQL1 天前
PostgreSQL 技术日报 (6月8日)|索引预取迭代,AI 安全功能上新
数据库·人工智能·sql·安全·postgresql
持敬chijing1 天前
Web渗透之SQL注入-SQLMAP使用笔记
数据库·sql·安全·web安全·网络安全·网络攻击模型
千里马学框架1 天前
重学Perfetto浏览器在线抓取trace及高频sql分享
android·sql·智能手机·架构·aaos·perfetto·车机
逍遥德1 天前
PostgreSQL --- 二进制数使用详解
数据库·sql·postgresql