Power AppsでSharePointリストとかから値を取得してくるとき、500件や2000件といったデータの上限数をよく耳にするので、この上限について調べてみた。
データ数制限:500件とは
Power Appsのデータの上限としてよく聞く「500件」とは、↓の公式サイトにある「委任できない場合の制限」のこと。
https://docs.microsoft.com/ja-jp/powerapps/maker/canvas-apps/delegation-overview#non-delegable-limits
要約すると、
- 委任できない数式はローカルで処理される
- その場合、事前に全データを取得する必要があるため、ネット経由で大量のデータを取得する可能性がある
- もちろん大幅に時間がかかることもあり、アプリの動作が遅い!という印象を与えるかも
- そこでPower Appsでは、ローカルで処理可能なデータ量を既定で500件としている
という内容。
要は「委任できない数式は既定で500件のみデータを持ってきて、委任できる数式は500件を超えるデータも持ってくることができる」とのこと。
そこで今回は500件を超すデータを「委任あり」と「委任なし」それぞれで持ってきた場合で表示を見比べてみる。
事前準備
今回用意したリストはこんな感じで501件のデータが入ったリスト。
data:image/s3,"s3://crabby-images/19e45/19e453f47e0c9d5ef32d15f71ff6ec1053702ef7" alt=""
data:image/s3,"s3://crabby-images/19e45/19e453f47e0c9d5ef32d15f71ff6ec1053702ef7" alt=""
それをこんな感じで「折り返し:10」で表示する。
data:image/s3,"s3://crabby-images/74742/747425d66c1e40497ecd4aa4db43bf677a816d60" alt=""
data:image/s3,"s3://crabby-images/74742/747425d66c1e40497ecd4aa4db43bf677a816d60" alt=""
ちなみにこの状態だと501件すべてのアイテムが表示される。
data:image/s3,"s3://crabby-images/aa1c7/aa1c7f5927c5358ea3cbb3c29f26791d4a3b3904" alt=""
data:image/s3,"s3://crabby-images/aa1c7/aa1c7f5927c5358ea3cbb3c29f26791d4a3b3904" alt=""
501件のデータを委任ありで表示した場合
501件のデータを委任ありFilterで表示するとこんな感じ。
data:image/s3,"s3://crabby-images/5e6cb/5e6cb3adab0493303029c5b2c9a92a3fddc9b8e9" alt=""
data:image/s3,"s3://crabby-images/5e6cb/5e6cb3adab0493303029c5b2c9a92a3fddc9b8e9" alt=""
501件のデータ全てが表示される。
501件のデータを委任なしで表示した場合
501件のデータを委任なしで表示するとこんな感じ。
data:image/s3,"s3://crabby-images/b3492/b349202e42535f40d0239036115c5634f061832c" alt=""
data:image/s3,"s3://crabby-images/b3492/b349202e42535f40d0239036115c5634f061832c" alt=""
画像のとおり500件のデータしか表示されない(持ってこない)。これがデータの上限数500件の正体。
データの上限数の変え方
データの上限数は[設定]の[全般]→[データ行の制限]で変更することができる。試しに500を501に変えてみて、
data:image/s3,"s3://crabby-images/6e075/6e07533c9308b8dc1c467f2be3a8b73ffe1de680" alt=""
data:image/s3,"s3://crabby-images/6e075/6e07533c9308b8dc1c467f2be3a8b73ffe1de680" alt=""
ギャラリーをリフレッシュすると、委任なしでも501件のデータが表示されるようになる。
data:image/s3,"s3://crabby-images/8f154/8f154fb182473525c12a2f8d44b92bfeb1262f26" alt=""
data:image/s3,"s3://crabby-images/8f154/8f154fb182473525c12a2f8d44b92bfeb1262f26" alt=""
このときSUM関数などの委任が効かない関数も、先頭500件しか計算対象にならない。
そこで、1~501を加算すると「125,751」になるはずが、↓の通り「125,250( + 501 = 125,751)」となってしまう。
data:image/s3,"s3://crabby-images/06084/06084202cf151c5be3c5a93fa8fa343f243e71bf" alt=""
data:image/s3,"s3://crabby-images/06084/06084202cf151c5be3c5a93fa8fa343f243e71bf" alt=""
おまけ:2001件のデータを扱ってみる
こんな感じで2001件のSharePointリストを作ってみて
data:image/s3,"s3://crabby-images/f35f5/f35f5a54f92dd466b3c5753ce76e035cfe4c07fb" alt=""
data:image/s3,"s3://crabby-images/f35f5/f35f5a54f92dd466b3c5753ce76e035cfe4c07fb" alt=""
まずは「委任あり」で表示。すると2001件データは表示されるけど、当然かなり重いw
data:image/s3,"s3://crabby-images/36360/36360ef8a75c163c56a200b19a39461859e8f624" alt=""
data:image/s3,"s3://crabby-images/36360/36360ef8a75c163c56a200b19a39461859e8f624" alt=""
続いて「委任なし」かつ「上限500件」で表示するとこんな感じ。さっきよりはだいぶ早い。
data:image/s3,"s3://crabby-images/62156/621567a98f8c43378570f9014c3cec1d910780b7" alt=""
data:image/s3,"s3://crabby-images/62156/621567a98f8c43378570f9014c3cec1d910780b7" alt=""
最後に上限を2000に変えて
data:image/s3,"s3://crabby-images/04c5d/04c5dbd663000407e775287992234b84bdff0ce7" alt=""
data:image/s3,"s3://crabby-images/04c5d/04c5dbd663000407e775287992234b84bdff0ce7" alt=""
ギャラリーをリフレッシュすると、2000件までデータが表示される。こちらも当然重いw
data:image/s3,"s3://crabby-images/119af/119af61d22459d804b87d94e8361c7150bfdf115" alt=""
data:image/s3,"s3://crabby-images/119af/119af61d22459d804b87d94e8361c7150bfdf115" alt=""
2021/8/30追記:
今回「データ行の制限」設定値以上のデータを表示できているのはギャラリーコントロールを使用しているからでした。
変数やコレクションを扱う場合はこちらの記事をご覧頂ければと思います。
data:image/s3,"s3://crabby-images/5b142/5b142818726f9198cc5128ccf1efd8170def50fb" alt=""
今回「データ行の制限」設定値以上のデータを表示できているのはギャラリーコントロールを使用しているからでした。
変数やコレクションを扱う場合はこちらの記事をご覧頂ければと思います。
data:image/s3,"s3://crabby-images/5b142/5b142818726f9198cc5128ccf1efd8170def50fb" alt=""
Power Apps 委任とデータ行の制限(500件~2000件)の関係を徹底解説|委任とデータ行の制限は分けて考える
これまで委任とデータ行の制限(既定は500件)が絡まると、いまいち理解がこんがらがってしまっていたけど、改めて図にしてみるとわかりやすかったのでメモ。前提前提として今回はこんなリストがあって、このリストを、わかりやすいようにデータ行の制限を...
コメント