Funzione h3_compact
Si applica a: Databricks SQL Databricks Runtime 11.3 LTS e versioni successive
Compatta l'input set delle celle di H3. Il set compattato copre lo stesso set di celle H3 della versione originale.
Sintassi
h3_compact ( h3CellIdsExpr )
Argomenti
-
h3CellIdsExpr
: matrice di espressioni BIGINT o MATRICE di espressioni STRINGs esadecimali che rappresentano una matrice di ID cella H3.
Valori restituiti
Una ARRAY di ID di celle H3 dello stesso tipo del values nell'espressione di ARRAY di input h3CellIdsExpr
.
La funzione restituisce NULL se l'input è NULL.
La funzione esegue la convalida parziale relativa al fatto che l'argomento di input sia un ID cella H3 valido. Una condizione necessaria, ma non sufficiente per un ID H3 valido è che il relativo valore è compreso tra 0x08001fffffffffff
e 0x08ff3b6db6db6db6
.
Il comportamento della funzione non è definito se uno degli ID di cella nell'array di input non è un ID di cella valido.
I values NULL nella matrice di input vengono ignorati.
Condizioni di errore
- Se
h3CellIdExpr
è un valore STRING che non può essere convertito in bigint o corrisponde a un valore BIGINT minore o maggiore di0x08001fffffffffff
0x08ff3b6db6db6db6
, la funzione restituisce H3_INVALID_CELL_ID.
Esempi
-- Example where the input is an ARRAY of BIGINTs
> SELECT h3_compact(ARRAY(599686042433355775,599686030622195711,599686044580839423,599686038138388479,599686043507097599,599686015589810175,599686014516068351,599686034917163007,599686029548453887,599686032769679359,599686198125920255,599686040285872127,599686041359613951,599686039212130303,599686023106002943,599686027400970239,599686013442326527,599686012368584703,599686018811035647));
[599686030622195711,599686015589810175,599686014516068351,599686034917163007,599686029548453887,599686032769679359,599686198125920255,599686023106002943,599686027400970239,599686013442326527,599686012368584703,599686018811035647,595182446027210751]
-- Example where the input is an ARRAY of hexadecimal STRINGs
> SELECT h3_compact(ARRAY('85283473fffffff', '85283447fffffff', '8528347bfffffff', '85283463fffffff', '85283477fffffff', '8528340ffffffff', '8528340bfffffff', '85283457fffffff', '85283443fffffff', '8528344ffffffff', '852836b7fffffff', '8528346bfffffff', '8528346ffffffff', '85283467fffffff', '8528342bfffffff', '8528343bfffffff', '85283407fffffff', '85283403fffffff', '8528341bfffffff'));
[85283447fffffff, 8528340ffffffff, 8528340bfffffff, 85283457fffffff, 85283443fffffff, 8528344ffffffff, 852836b7fffffff, 8528342bfffffff, 8528343bfffffff, 85283407fffffff, 85283403fffffff, 8528341bfffffff, 8428347ffffffff]
-- Example where the input ARRAY consists of a single element (and thus cannot be compacted further).
> SELECT h3_compact(ARRAY('85283473fffffff'));
[85283473fffffff]
-- Example where we compare the size of the 2-ring of an H3 cell with its compacted version.
> SELECT ARRAY_SIZE(h3_kring(599686042433355775, 2)), ARRAY_SIZE(h3_compact(h3_kring(599686042433355775, 2)))
19 13
-- Example where one of the cell IDs is out of range.
> SELECT h3_compact(ARRAY(599686042433355775, 0))
[H3_INVALID_CELL_ID] 0 is not a valid H3 cell ID