Funzioni di riferimento

Funzioni di riferimento

Il tipo REFERENCE funge da "puntatore" ad altri documenti nel database (o anche ad altri database). Le seguenti funzioni consentono di manipolare questo tipo durante l'esecuzione della query.

Nome Descrizione
COLLECTION_ID Restituisce l'ID della raccolta finale nel riferimento specificato
DOCUMENT_ID Restituisce l'ID del documento nel riferimento specificato
PARENT Restituisce il riferimento principale
REFERENCE_SLICE Restituisce un sottoinsieme di segmenti dal riferimento specificato.

COLLECTION_ID

Sintassi:

collection_id(ref: REFERENCE) -> STRING

Descrizione:

Restituisce l'ID della raccolta secondaria del REFERENCE specificato.

Esempi:

ref collection_id(ref)
users/user1 "users"
users/user1/posts/post1 "posts"

DOCUMENT_ID

Sintassi:

document_id(ref: REFERENCE) -> ANY

Descrizione:

Restituisce l'ID documento del REFERENCE specificato.

Esempi:

ref document_id(ref)
users/user1 "user1"
users/user1/posts/post1 "post1"

GENITORE

Sintassi:

parent(ref: REFERENCE) -> REFERENCE

Descrizione:

Restituisce il genitore REFERENCE del riferimento specificato o NULL se il riferimento è già un riferimento principale.

Esempi:

ref parent(ref)
/ NULL
users/user1 /
users/user1/posts/post1 users/user1

REFERENCE_SLICE

Sintassi:

reference_slice(ref: REFERENCE, offset: INT, length: INT) -> REFERENCE

Descrizione:

Un REFERENCE è un elenco di tuple (collection_id, document_id) e consente di visualizzare l'elenco, proprio come array_slice(...).

Restituisce un nuovo REFERENCE che è un sottoinsieme dei segmenti del ref specificato.

  • offset: l'indice iniziale (a base 0) della sezione. Se è negativo, è un offset dalla fine del riferimento.
  • length: il numero di segmenti da includere nella sezione.

Esempi:

ref offset length reference_slice(ref, offset, length)
a/1/b/2/c/3 1L 2L b/2/c/3
a/1/b/2/c/3 0L 2L a/1/b/2
a/1/b/2/c/3 -2L 2L c/3