フィールドを追加

説明

前のステージで生成されたドキュメントに新しいフィールドを追加します。

生成されたドキュメントには、前のステージのすべてのフィールドと、新しく追加されたすべてのフィールドが含まれます。前のドキュメントと同じ名前のフィールドは上書きされます。

構文

Node.js

const results = await db.pipeline()
  .collection("/users")
  .addFields(field('first_name').concat(' ', field('last_name')).as('full_name'))
  .execute();

クライアントの例

Web

const result = await execute(db.pipeline()
  .collection("books")
  .select(field("soldBooks").add(field("unsoldBooks")).as("totalBooks"))
);
Swift
let result = try await db.pipeline()
  .collection("books")
  .select([Field("soldBooks").add(Field("unsoldBooks")).as("totalBooks")])
  .execute()

Kotlin

val result = db.pipeline()
    .collection("books")
    .select(Expression.add(field("soldBooks"), field("unsoldBooks")).alias("totalBooks"))
    .execute()

Java

Task<Pipeline.Snapshot> result = db.pipeline()
    .collection("books")
    .select(Expression.add(field("soldBooks"), field("unsoldBooks")).alias("totalBooks"))
    .execute();
Python
from google.cloud.firestore_v1.pipeline_expressions import Field

result = (
    client.pipeline()
    .collection("books")
    .select(Field.of("soldBooks").add(Field.of("unsoldBooks")).as_("totalBooks"))
    .execute()
)
Java
Pipeline.Snapshot result =
    firestore
        .pipeline()
        .collection("books")
        .select(add(field("soldBooks"), field("unsoldBooks")).as("totalBooks"))
        .execute()
        .get();

動作

重複するフィールド

前のステージのドキュメントにすでに存在するエイリアスを式に割り当てると、add_fields(...) ステージで前のフィールドが上書きされます。

これを利用して、次のように同じフィールド名で複数の式を連結することができます。

Node.js

const results = await db.pipeline()
  .collection("/users")
  .addFields(field('age').abs().as('age'))
  .addFields(field('age').add(10).as('age'))
  .execute();

フィールドのネスト

新しく追加されたフィールドに割り当てられたエイリアスには . などの特殊文字を含めることができますが、これらはトップレベル フィールドとして扱われます。次に例を示します。

Node.js

const results = await db.pipeline()
  .collection("/users")
  .addFields(field('address.city').toLower().as('address.city'))
  .execute();

式の結果を address のネストされたマップにマージするのではなく、新しいトップレベル フィールド address.city を追加します。