تصحيح أخطاء الدوال
| الاسم | الوصف |
EXISTS
|
تعرِض TRUE إذا لم تكن القيمة قيمة غائبة
|
IS_ABSENT
|
تعرض الدالة TRUE إذا كانت القيمة قيمة غائبة
|
IF_ABSENT
|
يستبدل القيمة بتعبير إذا كانت غير متوفّرة |
IS_ERROR
|
تتلقّى هذه الدالة ما إذا كان التعبير الأساسي قد طرح خطأً وتتحقّق من ذلك. |
IF_ERROR
|
يستبدل القيمة بتعبير إذا حدث خطأ |
ERROR
|
تنهي عملية التقييم وتعرض خطأً مع الرسالة المحدّدة |
EXISTS
البنية:
exists(value: ANY) -> BOOLEAN
الوصف:
تعرض TRUE إذا لم تكن value هي القيمة الغائبة.
أمثلة:
value |
exists(value) |
|---|---|
| 0L | TRUE |
| "foo" | TRUE |
NULL |
TRUE |
ABSENT |
FALSE |
Node.js
const result = await db.pipeline() .collection("books") .select(field("rating").exists().as("hasRating")) .execute();
Web
مثال:
const result = await execute(db.pipeline() .collection("books") .select(field("rating").exists().as("hasRating")) );
Swift
let result = try await db.pipeline() .collection("books") .select([Field("rating").exists().as("hasRating")]) .execute()
Kotlin
مثال:
val result = db.pipeline() .collection("books") .select(field("rating").exists().alias("hasRating")) .execute()
Java
مثال:
Task<Pipeline.Snapshot> result = db.pipeline() .collection("books") .select(field("rating").exists().alias("hasRating")) .execute();
Python
from google.cloud.firestore_v1.pipeline_expressions import Field result = ( client.pipeline() .collection("books") .select(Field.of("rating").exists().as_("hasRating")) .execute() )
Java
Pipeline.Snapshot result = firestore .pipeline() .collection("books") .select(exists(field("rating")).as("hasRating")) .execute() .get();
IS_ABSENT
البنية:
is_absent(value: ANY) -> BOOLEAN
الوصف:
تعرض الدالة TRUE إذا كانت value هي القيمة الغائبة، وتعرض FALSE في الحالات الأخرى. القيم غير المتوفّرة هي القيم التي لا تظهر في الإدخال، مثل حقل مستند غير متوفّر.
أمثلة:
value |
is_absent(value) |
|---|---|
| 0L | FALSE |
| "foo" | FALSE |
NULL |
FALSE |
ABSENT |
TRUE |
IF_ABSENT
البنية:
if_absent(value: ANY, replacement: ANY) -> ANY
الوصف:
إذا كانت value قيمة غير متوفّرة، يتم تقييم replacement وعرضها. بخلاف ذلك، تعرض value.
أمثلة:
value |
replacement |
if_absent(value, replacement) |
|---|---|---|
| 5L | 0L | 5L |
NULL |
0L | NULL |
ABSENT |
0L | 0L |
IS_ERROR
البنية:
is_error(try: ANY) -> BOOLEAN
الوصف:
تعرض هذه الدالة TRUE إذا حدث خطأ أثناء تقييم try. تعرض FALSE في الحالات الأخرى.
IF_ERROR
البنية:
if_error(try: ANY, catch: ANY) -> ANY
الوصف:
إذا حدث خطأ أثناء تقييم try، يتم تقييم replacement وعرضها. بخلاف ذلك، تعرض القيمة التي تمّ حلّها لـ try.
خطأ
البنية:
error(message: STRING) -> ANY
الوصف:
يؤدي تقييم الدالة error إلى تقييم خط الأنابيب بغرض إنهاء العملية مع حدوث خطأ. يتم تضمين message المحدّد في الخطأ.
أمثلة:
cond |
res |
switch_on(cond, res, error("no condition matched")) |
|---|---|---|
TRUE |
1L | 1L |
FALSE |
1L | ERROR ("no condition matched") |