1
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 3 years have passed since last update.

kintoneでレコード全件について関連レコードの項目を集計して更新する機能を泥臭くカスタマイズする【その2】

Last updated at Posted at 2021-11-24

前回は、一覧画面から1件更新するボタンを作りました。

今回は、3件分のレコードについて、1件ずつ集計して更新してみたいと思います。

見出しの記号の説明
🙄:考えるところ
🛠️:手を動かすところ

🙄3件集計して更新する

3件というわけで、とりあえず今回はレコード番号20,19,18のレコードを集計するようにしましょう
(一覧にレコード番号を追加するとわかりやすいですね)

image.png

🛠️3件分ベタ書きで書いてみよう

前回、ボタンクリックで1件更新するコードは下記のようになりました。

// ボタンクリックした時のコード
// 関連レコード集計用リクエストパラメータ準備
const clientRecordId = 19;
const relatedAppId = kintone.app.getRelatedRecordsTargetAppId("案件一覧");
const query =
  '顧客管理レコード番号_関連レコード紐付け用="' +
  clientRecordId +
  '" and 提案プラン in ("Aプラン")';
const outputFields = ["合計費用"];
const params = {
  app: relatedAppId,
  query: query,
  fields: outputFields,
};
console.log(params);

// 集計値を取得する
const client = new KintoneRestAPIClient();
const res = await client.record.getRecords(params);
console.log(res);

// 合計金額集計
const amount = res.records.reduce(
  (preV, p) => preV + parseFloat(p.合計費用.value),
  0
);

// レコードを更新する
const rec = {
  Aプラン小計: {
    value: amount,
  },
};
const res2 = await client.record.updateRecord({
  app: kintone.app.getId(),
  id: 19,
  record: rec,
});
location.reload();

これを、レコード番号20,19,18の3件分に増やします。
同じ変数名は使わないようにテキトウに変数名かぶらないようにしながら3件分書くと、
↓こんな感じになります。※clientは一番上に出しておきましょう。

// ボタンクリックした時のコード
const client = new KintoneRestAPIClient();

// 関連レコード集計用リクエストパラメータ準備
const relatedAppId = kintone.app.getRelatedRecordsTargetAppId("案件一覧");

// レコード番号20
const query =
  '顧客管理レコード番号_関連レコード紐付け用="' +
  20 +
  '" and 提案プラン in ("Aプラン")';
const outputFields = ["合計費用"];
const params = {
  app: relatedAppId,
  query: query,
  fields: outputFields,
};

// 集計値を取得する
const res = await client.record.getRecords(params);
// 合計金額集計
const amount = res.records.reduce(
  (preV, p) => preV + parseFloat(p.合計費用.value),
  0
);

// レコードを更新する
const rec = {
  Aプラン小計: {
    value: amount,
  },
};
const res2 = await client.record.updateRecord({
  app: kintone.app.getId(),
  id: 20,
  record: rec,
});

// レコード番号19
const query2 =
  '顧客管理レコード番号_関連レコード紐付け用="' +
  19 +
  '" and 提案プラン in ("Aプラン")';
const params2 = {
  app: relatedAppId,
  query: query2,
  fields: outputFields,
};

// 集計値を取得する
const res3 = await client.record.getRecords(params2);
// 合計金額集計
const amount2 = res3.records.reduce(
  (preV, p) => preV + parseFloat(p.合計費用.value),
  0
);
// レコードを更新する
const rec2 = {
  Aプラン小計: {
    value: amount2,
  },
};
const res4 = await client.record.updateRecord({
  app: kintone.app.getId(),
  id: 19,
  record: rec2,
});

// レコード番号18
const query3 =
  '顧客管理レコード番号_関連レコード紐付け用="' +
  18 +
  '" and 提案プラン in ("Aプラン")';
const param3 = {
  app: relatedAppId,
  query: query3,
  fields: outputFields,
};

// 集計値を取得する
const res5 = await client.record.getRecords(param3);
// 合計金額集計
const amount3 = res5.records.reduce(
  (preV, p) => preV + parseFloat(p.合計費用.value),
  0
);
// レコードを更新する
const rec3 = {
  Aプラン小計: {
    value: amount3,
  },
};
const res6 = await client.record.updateRecord({
  app: kintone.app.getId(),
  id: 18,
  record: rec3,
});
location.reload();

コレを動かしてみると・・・・👀
※レコード番号を一覧に表示しておくとわかりやすいかな。
image.png

レコード番号20,19,18のAプラン小計が更新されます✨✨こんなふうになればOK!

🙄ベタ書き、全部書くわけにも行かないよね!

3件だったのでベタ書きでもなんとかコードを書けましたが、コレ、ベタ書きにせずに書く方法ないかな?
というわけで、キレイにまとめる方法を考えてみたいと思います。

🙄ベタ書きしたコードの中の共通点を見つける

共通点か~。まてよ?
レコード番号が20,19,18ということ以外は共通なはずだ!
ということは、レコード番号をXXXってしてみると、
レコード番号XXXだったらこんな感じに書き換えられるよね👀✨✨

// レコード番号をXXXとすると~??
const query =
  '顧客管理レコード番号_関連レコード紐付け用="' +
  XXX +
  '" and 提案プラン in ("Aプラン")';
const outputFields = ["合計費用"];
const params = {
  app: relatedAppId,
  query: query,
  fields: outputFields,
};

// 集計値を取得する
const res = await client.record.getRecords(params);
// 合計金額集計
const amount = res.records.reduce(
  (preV, p) => preV + parseFloat(p.合計費用.value),
  0
);

// レコードを更新する
const rec = {
  Aプラン小計: {
    value: amount,
  },
};
const res2 = await client.record.updateRecord({
  app: kintone.app.getId(),
  id: XXX,
  record: rec,
});

そして、思います。
レコード番号が複数あるので、XXXは配列にしてみたらいいのではないか??

🛠️レコード番号を配列にして、ループしてみよう。

先程のコードのXXXを
const XXX = [20,19,18];
という配列にして、forループで動かしてみましょう👀

また、
const outputFields = ["合計費用"]

と、合計金額集計の
(preV, p) => preV + parseFloat(p.合計費用.value),
合計費用は繰り返し出てきているので、合計金額集計の方は
↓こうしておきましょう👀
(preV, p) => preV + parseFloat(p[outputFields[0]].value),


// レコード番号XXX
const XXX = [20, 19, 18];
for (let i = 0; i < XXX.length; i++) {
  const query =
    '顧客管理レコード番号_関連レコード紐付け用="' +
    XXX[i] +
    '" and 提案プラン in ("Aプラン")';
  const outputFields = ["合計費用"];
  const params = {
    app: relatedAppId,
    query: query,
    fields: outputFields,
  };

  // 集計値を取得する
  const res = await client.record.getRecords(params);
  // 合計金額集計
  const amount = res.records.reduce(
    (preV, p) => preV + parseFloat(p[outputFields[0]].value),
    0
  );

  // レコードを更新する
  const rec = {
    Aプラン小計: {
      value: amount,
    },
  };
  const res2 = await client.record.updateRecord({
    app: kintone.app.getId(),
    id: XXX[i],
    record: rec,
  });
}

コレでうまく3件分の更新ができたはずです👀
(ちゃんと集計できたかな👀?)
紐づく案件のプランを変更してみたりして、値を変えてボタンを押してみるとちゃんと計算できているかどうか分かるね!

うまくコードを繋げられない(><)という方は、
ここまでを何度も読んだり書いてみたり、試行錯誤してみてね👀!
※どこに書けばいいのかなどは、あえて書いていなかったりします。試行錯誤頑張ってくださいっ!

というわけで今回の内容はおしまい。
次回は1件ずつを繰り返す方法を覆すのでお楽しみに。

image.png

1
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
1
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?