跳到主要内容
版本:Candidate-3.4

sub_bitmap

根据 offset 指定的起始位置,从 BITMAP 类型的 src 中截取 len 个元素,返回的元素为 src 的子集。该函数主要用于分页查询相关场景。该函数从 2.5 版本开始支持。

该函数与 bitmap_subset_limit 功能相似,不同之处在于 bitmap_subset_limit 指定的是起始值,sub_bitmap 指定的是 offset。

语法

BITMAP sub_bitmap(BITMAP src, BIGINT offset, BIGINT len)

参数说明

  • src: 要截断的目标 bitmap。

  • offset: 用于指定起始位置,支持的数据类型为 BIGINT。Offset 的使用注意事项:

    • Offset 从 0 开始。
    • 负偏移量指的是从字符串结尾开始从右向左计数,见示例三和四。
    • offset 指定的起始位置不能超出 BITMAP 值的实际长度,否则返回 NULL,见示例六。
  • len: 要截取的元素个数,必须为正整数,否则返回 NULL。如果符合条件的元素个数小于 len 取值,则返回满足条件的所有元素,见示例二、三、七。

返回值说明

返回值的数据类型为 BITMAP。如果输入参数非法,则返回 NULL。

示例

在以下示例中,sub_bitmap() 函数的输入值为 bitmap_from_string 函数计算后的结果。比如示例中的 bitmap_from_string('1,1,3,1,5,3,5,7,7,9') 实际输出的 BITMAP 值为 1, 3, 5, 7, 9。sub_bitmap() 会基于这个值进行计算。

示例一:从偏移量 0 开始,截取 BITMAP 值中 2 个元素。

select bitmap_to_string(sub_bitmap(bitmap_from_string('1,1,3,1,5,3,5,7,7,9'), 0, 2)) value;
+-------+
| value |
+-------+
| 1,3 |
+-------+

示例二:从偏移量 0 开始,截取 BITMAP 值中 100 个元素。由于 BITMAP 值中没有 100 个元素,所以输出符合条件的所有元素。

select bitmap_to_string(sub_bitmap(bitmap_from_string('1,1,3,1,5,3,5,7,7,9'), 0, 100)) value;
+-----------+
| value |
+-----------+
| 1,3,5,7,9 |
+-----------+

示例三:从偏移量 -3 开始,截取 BITMAP 值中 100 个元素。由于 BITMAP 值中没有 100 个元素,所以输出符合条件的所有元素。

select bitmap_to_string(sub_bitmap(bitmap_from_string('1,1,3,1,5,3,5,7,7,9'), -3, 100)) value;
+-------+
| value |
+-------+
| 5,7,9 |
+-------+

示例四:从偏移量 -3 开始,截取 BITMAP 值中 2 个元素。

select bitmap_to_string(sub_bitmap(bitmap_from_string('1,1,3,1,5,3,5,7,7,9'), -3, 2)) value;
+-------+
| value |
+-------+
| 5,7 |
+-------+

示例五:-10len 的非法输入,返回 NULL。

select bitmap_to_string(sub_bitmap(bitmap_from_string('1,1,3,1,5,3,5,7,7,9'), 0, -10)) value;
+-------+
| value |
+-------+
| NULL |
+-------+

示例六:offset 指定的起始位置 5 超出 BITMAP 值 1,3,5,7,9 的长度,返回 NULL。

select bitmap_to_string(sub_bitmap(bitmap_from_string('1,1,3,1,5,3,5,7,7,9'), 5, 1)) value;
+-------+
| value |
+-------+
| NULL |
+-------+

示例七:实际符合条件的元素只有 2 个,小于 len 的值 5,返回所有满足条件的元素。

select bitmap_to_string(sub_bitmap(bitmap_from_string('1,1,3,1,5,3,5,7,7,9'), -2, 5)) value;
+-------+
| value |
+-------+
| 7,9 |
+-------+