Funções Type

Funções de tipo

Nome Descrição
TYPE Retorna o tipo do valor como um STRING.
IS_TYPE Retorna true se o valor corresponder ao tipo especificado.

TYPE

Sintaxe:

type(input: ANY) -> STRING

Descrição:

Retorna uma representação de string do tipo input.

Se um valor ausente for fornecido, vai retornar NULL.

Exemplos:

input type(input)
NULL "null"
verdadeiro "boolean"
1 "int32"
-3L "int64"
3.14 "float64"
2024-01-01T00:00:00Z UTC "timestamp"
"foo" "string"
b"foo" "bytes"
[1, 2] "array"
{"a": 1} "map"
path("c/d") "reference"
vector([1.0, 2.0]) "vector"
AUSENTE NULL

Exemplos de clientes

Node.js
const result = await db.pipeline()
  .collection("books")
  .select(field("title").notEqual("1984").as("not1984"))
  .execute();

Web

const result = await execute(db.pipeline()
  .collection("books")
  .select(field("title").notEqual("1984").as("not1984"))
);
Swift
let result = try await db.pipeline()
  .collection("books")
  .select([Field("title").notEqual("1984").as("not1984")])
  .execute()

Kotlin

val result = db.pipeline()
    .collection("books")
    .select(field("title").notEqual("1984").alias("not1984"))
    .execute()

Java

Task<Pipeline.Snapshot> result = db.pipeline()
    .collection("books")
    .select(field("title").notEqual("1984").alias("not1984"))
    .execute();
Python
from google.cloud.firestore_v1.pipeline_expressions import Field

result = (
    client.pipeline()
    .collection("books")
    .select(Field.of("title").not_equal("1984").as_("not1984"))
    .execute()
)
Java
Pipeline.Snapshot result =
    firestore
        .pipeline()
        .collection("books")
        .select(notEqual(field("title"), "1984").as("not1984"))
        .execute()
        .get();

IS_TYPE

Sintaxe:

is_type(input: ANY, type: STRING) -> BOOLEAN

Descrição:

Retorna true se o input corresponder ao type especificado. Caso contrário, retorna false. Se um input ausente for fornecido, vai retornar NULL.

As strings type compatíveis são:

  • "null"
  • "boolean"
  • "int32"
  • "int64"
  • "float64"
  • "decimal128"
  • "number"
  • "timestamp"
  • "string"
  • "bytes"
  • "array"
  • "map"
  • "reference"
  • "vector"
  • "geo_point"
  • "max_key"
  • "min_key"
  • "object_id"
  • "regex"
  • "bson_timestamp"

Exemplos:

input type is_type(input, type)
NULL "null" verdadeiro
verdadeiro "boolean" verdadeiro
3.14 "float64" verdadeiro
"foo" "string" verdadeiro
b"foo" "string" falso
[1, 2] "array" verdadeiro
{"a": 1} "map" verdadeiro
vector([1.0, 2.0]) "vector" verdadeiro
AUSENTE "string" NULL
"barra" "outro" ERRO