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) -> 过滤条件 )
相关推荐
唐青枫5 天前
MySQL JSON 实战详解:从存储、查询、更新到 JSON_TABLE 与索引
sql·mysql
掉头发的王富贵6 天前
【StarRocks】极限十分钟入门StarRocks
数据库·sql·mysql
zzzzzz31012 天前
9K Star 炸裂开源!这个 C 语言写的代码知识图谱,把 Linux 内核索引压缩到了 3 分钟
linux·服务器·sql
云技纵横14 天前
唯一索引 INSERT 死锁实战:5 秒复现交叉插入的 S 锁循环等待
sql·mysql
BD_Marathon15 天前
SQL学习指南——视图
数据库·sql
2601_9620725515 天前
李梦娇常识4600问|题库|打印版
sql·华为od·华为·c#·华为云·.net·harmonyos
HackTwoHub15 天前
Sqli-Scanner SQL注入SKILL自动化挖掘SQL注入,零依赖自动化SQL注入挖掘,赏金猎人
数据库·人工智能·sql·web安全·网络安全·自动化·系统安全
Volunteer Technology15 天前
Flink Table API与SQL(一)
大数据·sql·flink
持敬chijing16 天前
Web渗透之SQL注入-常用sql语句
sql·安全·web安全·网络安全
Theo·Chan16 天前
更换 Kingbase V9 License 踩坑记
sql·信创·kingbase