Passer au contenu principal

groupBitmapOr

Introduit dans : v20.1.0 Calcule le OR d’une colonne bitmap et renvoie sa cardinalité. Si le suffixe de combinateur -State est ajouté, la fonction renvoie alors un objet bitmap. Cela équivaut à groupBitmapMerge (groupBitmap avec le suffixe de combinateur -Merge). Syntaxe
groupBitmapOr(expr)
groupBitmapOrState(expr)
Arguments Valeur renvoyée Renvoie un nombre de type UInt64, ou un objet bitmap lors de l’utilisation de -State. UInt64 Exemples Exemple d’utilisation
Query
CREATE TABLE bitmap_column_expr_test2
(
    tag_id String,
    z AggregateFunction(groupBitmap, UInt32)
)
ENGINE = MergeTree
ORDER BY tag_id;

INSERT INTO bitmap_column_expr_test2 VALUES ('tag1', bitmapBuild(cast([1,2,3,4,5,6,7,8,9,10] AS Array(UInt32))));
INSERT INTO bitmap_column_expr_test2 VALUES ('tag2', bitmapBuild(cast([6,7,8,9,10,11,12,13,14,15] AS Array(UInt32))));
INSERT INTO bitmap_column_expr_test2 VALUES ('tag3', bitmapBuild(cast([2,4,6,8,10,12] AS Array(UInt32))));

SELECT groupBitmapOr(z) FROM bitmap_column_expr_test2 WHERE like(tag_id, 'tag%');
Response
┌─groupBitmapOr(z)─┐
│             15   │
└──────────────────┘
Utilisation du combinateur -State
Query
SELECT arraySort(bitmapToArray(groupBitmapOrState(z))) FROM bitmap_column_expr_test2 WHERE like(tag_id, 'tag%');
Response
┌─arraySort(bitmapToArray(groupBitmapOrState(z)))─┐
│ [1,2,3,4,5,6,7,8,9,10,11,12,13,14,15]           │
└─────────────────────────────────────────────────┘
Dernière modification le 29 juin 2026