よく聞くけど、SharePoint リストの 5,000 件問題ってなんなの?

493.1K Views

May 09, 22

スライド概要

Microsoft 365 Virtual Marathon 2022 でお話した資料です。

YouTube / よく聞く「SharePoint リストの 5,000 件問題」ってなんなの? - Hirofumi Ota
https://www.youtube.com/watch?v=08W1Y012P9c

Microsoft 365 Virtual Marathon
https://www.m365virtualmarathon.com/

Microsoft 365 Virtual Marathon 2022 Japanese Track
https://connpass.com/event/243871/

profile-image

Microsoft 365 の情報をチェックしています!

シェア

またはPlayer版

埋め込む »CMSなどでJSが使えない場合

(ダウンロード不可)

関連スライド

各ページのテキスト
1.

MICROSOFT 365 VIRTUAL MARATHON 2022 MAY, 4 – 6, 2022 OTA HIROFUMI / 太田 浩史 Microsoft MVP for Office Apps & Services @hrfmjp hrfmjp idea.tostring.jp SharePoint リストの 5,000 件問題

2.

MICROSOFT 365 VIRTUAL MARATHON 2022 SPONSORS M365VIRTUALMARATHON.COM #M365VM

3.

OTA HIROFUMI / 太田 浩史 Microsoft MVP for Office Apps & Services ▪ 株式会社内田洋行 ▪ Twitter: twitter.com/hrfmjp ▪ LinkedIn: www.linkedin.com/in/hrfmjp ▪ Blog: idea.tostring.jp ▪ Microsoft Teams 踏み込み活用術 M365VIRTUALMARATHON.COM #M365VM

4.

このセッションの内容 • そもそも 5,000 件問題とは • SharePoint の対応 • モダンリストの動作 • まとめ M365VIRTUALMARATHON.COM #M365VM

5.

免責 • 調査・検証の結果をまとめた自由研究です • 検証は 2022 年 4 月中旬ごろ行いました • SharePoint Online のアップデートにより動作が変更されることがあります M365VIRTUALMARATHON.COM #M365VM

6.

こんな噂を聞いたことはありませんか? SharePoint リストには 5,000 件までしか保存できない? いまは 20,000 件でしょ? モダンリストを使えば 20,000 件なんだよね M365VIRTUALMARATHON.COM 5,000 件超えると何が起こるの? SharePoint 5,000 件問題 結局のところ、 5,000 件問題ってなに? すでにリストには 30,000 件も アイテムが入ってるんだけど? #M365VM

7.

令和の都市伝説 5,000 件問題は実在した!! M365VIRTUALMARATHON.COM #M365VM

8.

調査の前提条件 • リストには 100,000 件ほどのアイテムを保存 • すべてのアイテムはリストのルートに作成(フォルダー分けをしていない) M365VIRTUALMARATHON.COM #M365VM

9.

MICROSOFT 365 VIRTUAL MARATHON 2022 MAY, 4. – 6. 2022 そもそも 5,000 件問題とは

10.

そもそもなぜ 5,000 件問題が存在するのか う~ん、大変 SharePoint に入っている データをまとめて処理しちゃお SharePoint に過度の負荷がかかるのを避けるため M365VIRTUALMARATHON.COM #M365VM

11.

そもそもなぜ 5,000 件問題が存在するのか 昔のオンプレミスの SharePoint の動作 SQL Server データ テーブル レコード 1 SharePoint に入っている データをまとめて処理しちゃお レコード 2 レコード 3 ・・・ レコード 10000 レコード 10001 ・・・ 5,000 ロック エスカレーション 一定数以上の行ロックが発生したらテーブル全体をロック M365VIRTUALMARATHON.COM #M365VM

12.

そもそもなぜ 5,000 件問題が存在するのか 処理が終わるまで後続の処理をブロック SQL Server データ テーブル レコード 1 レコード 2 レコード 3 ・・・ レコード 10000 レコード 10001 🥺 ・・・ M365VIRTUALMARATHON.COM #M365VM

13.

そもそもなぜ 5,000 件問題が存在するのか 5,000 件より多くを対象とした処理をブロック SQL Server データ テーブル レコード 1 SharePoint が ブロックします! レコード 2 レコード 3 ・・・ 😊 レコード 10000 レコード 10001 ・・・ より多くのユーザー要求を処理できる M365VIRTUALMARATHON.COM #M365VM

14.

つまり 5,000 件問題とは 5,000 件よりも多くのアイテムを 一度に 処理できない 保存できない SharePoint リストには最大 3,000 万件のデータが格納できる M365VIRTUALMARATHON.COM #M365VM

15.

どんな処理が対象となるか 5,000 件よりも多くのアイテムを • • • • 一度に取得する処理 並び替える処理 フィルターする処理 グループ化する処理 など M365VIRTUALMARATHON.COM #M365VM

16.

5,000 件問題はいまでも私たちの身近に存在する M365VIRTUALMARATHON.COM #M365VM

17.

MICROSOFT 365 VIRTUAL MARATHON 2022 SharePoint の対応 MAY, 4. – 6. 2022

18.

一度に取得するアイテム数を制限する 遅延読み込み • ビューの表示に必要な数のアイテムを取得 • 以降のアイテムはユーザーのスクロールに 合わせて順次取得していく • 多くのアイテムを一度に取得しないことで データが多いときのパフォーマンスを向上 一番下まできたら 次の表示に必要な アイテムを読み込む M365VIRTUALMARATHON.COM #M365VM

19.

ちょっと具体的な処理を考える リストから更新日時の新しい順にアイテムを 5 件取得して表示する リストのデータ アイテム 途中の処理 更新日時 アイテム 取得するデータ 更新日時 アイテム 更新日時 アセロラ 2022/3/10 アセロラ 2022/3/10 ライチ 2022/4/20 パパイア 2022/1/20 パパイア 2022/1/20 レモン 2022/4/20 マルメロ 2022/1/8 マルメロ 2022/1/8 リンゴ 2022/4/20 マンゴー 2022/4/19 ・・・ ・・・ モモ 2022/4/3 モモ 2022/4/3 プルーン 2022/4/19 ライチ 2022/4/20 ライチ 2022/4/20 ライチ 2022/4/19 ・・・ ・・・ ・・・ 全件を対象とした並び替え処理がブロックされる M365VIRTUALMARATHON.COM #M365VM

20.

列インデックスの利用 SharePoint が効率よくデータを扱うための機能 アイテム 更新日時 アセロラ 2022/3/10 パパイア 2022/1/20 マルメロ 2022/1/8 ・・・ モモ 2022/4/3 ライチ 2022/4/20 ・・・ アセロラは あそこだな スグに取り出せるように 前もって整理しとこ… マルメロって なんだろう? ライチは下の 方にあるな インデックスがあれば 5,000 件を超える処理も実行できる M365VIRTUALMARATHON.COM #M365VM

21.

列インデックスの作成 4 1 2 3 5 [リストの設定] から設定画面を開き、 2 [インデックス付きの列] をクリック。インデックス付きの列の 設定画面で、 3 [新しいインデックスの作成] をクリックし、 4 インデックスを付けたい列を選択した後 5 [作成] ボタンを押すとインデックスが作成される 1 ID 列は、列インデックスを作成しなくてもインデックス付きの列として動作 M365VIRTUALMARATHON.COM #M365VM

22.

列インデックスをサポートする列 種類によってインデックスの作成可否が異なる サポートされている列の種類 • • • • • • • • • 1行テキスト 選択肢 数値 通貨 日付と時刻 はい/いいえ 個人 管理されたメタデータ ルックアップ サポートされていない列の種類 • • • • • • 複数行テキスト 選択肢(複数値) 集計値 ハイパーリンク 個人(複数値) 管理されたメタデータ(複数) ルックアップ列と呼ばれる種類の列では、 インデックスでも 5,000 件問題を完全には回避できない 参考: リストまたはライブラリ列にインデックスを追加する M365VIRTUALMARATHON.COM #M365VM

23.

列インデックスの動作 フィルターが出来る M365VIRTUALMARATHON.COM 並び替えが出来る #M365VM

24.

列インデックスの自動作成 列インデックスはユーザー操作に応じて自動作成されることがある あっ!並び替えた! インデックス作っておこ リスト内のアイテムが 5,000 件を超えている場合の操作で作成される ※ ルックアップ列は列インデックスは自動作成されませんでした M365VIRTUALMARATHON.COM #M365VM

25.

20,000 件問題 問題 列インデックスの自動作成はアイテム数が 20,000 件以下の場合にしか動作しない 解決策 20,000 件を超えたら 列インデックスを手動で作成する ※ SharePoint Online ではアイテム数によらず列インデックスを作成できる ただし、現時点の動作を実際に確認すると、 20,000 件を超えていても列インデックスは自動作成されました M365VIRTUALMARATHON.COM 公式情報が どこにもない… #M365VM

26.

ここまでのまとめ 5,000 件問題は処理負荷を軽減し、より多くのユーザーの要求を 処理するために SharePoint が設けている制限 列インデックスを作成することで、制限を回避することができる 列インデックスはユーザー操作に応じて自動作成されることがある 自動作成されなければ、手動で作成したら良い M365VIRTUALMARATHON.COM #M365VM

27.

MICROSOFT 365 VIRTUAL MARATHON 2022 モダンリストの動作 MAY, 4. – 6. 2022

28.

インデックス付き列の動作 フィルターが出来る M365VIRTUALMARATHON.COM 並び替えが出来る #M365VM

29.

ルックアップ列のインデックスの制限 フィルターは出来る 並び替えは出来ない 並び替えたフリ M365VIRTUALMARATHON.COM #M365VM

30.

インデックスが付かない列のフィルター動作 フィルターが出来る フィルターが出来ない? 一体なにが 起きているのか? M365VIRTUALMARATHON.COM #M365VM

31.

5,000 件問題フローチャート 操作対象のアイテム数は 5,000 件以下か? はい いいえ 列インデックスが 利用できる操作か? 問題なく動作 はい 並び替えやフィルターが 問題なく動作する いいえ ? ※ ルックアップ列に制限 M365VIRTUALMARATHON.COM #M365VM

32.

インデックスが付かない列のフィルター動作 アイテム 栽培地 熱帯 パパイア 熱帯 マルメロ 暖地, 寒冷地 ・・・ ・・・ マンゴー 熱帯 アンズ 寒冷地 上位 20,000 件を評価 アセロラ 列インデックスを持たない列でフィルターされた場合、 現在の並び順に従い上位から 20,000 件のアイテムを評価 フィルターに適合する アイテムがある フィルターに適合する アイテムがない ・・・ ・・・ モモ 暖地, 寒冷地 ライチ 熱帯 ・・・ M365VIRTUALMARATHON.COM #M365VM

33.

インデックスが付かない列の動作 アイテム 栽培地 アセロラ 熱帯 パパイア 熱帯 マルメロ 暖地, 寒冷地 ・・・ ・・・ マンゴー 熱帯 アンズ 寒冷地 ・・・ モモ 暖地, 寒冷地 ライチ 熱帯 ・・・ M365VIRTUALMARATHON.COM 次の 20,000 件を評価 ・・・ 「その他のアイテムを読み込む」をクリックすると 次の 20,000 件のアイテムを評価する 以降、アイテムが見つかるまで繰り返し #M365VM

34.

インデックスが付かない列の内部処理 RenderListDataAsStream • 上位から 5,000 件ずつに分割し フィルターを実行 • 一度に 4 回リクエストを送り 5,000 x 4 = 20,000 件 を 処理するようになっている • 4 回のリクエストを待たずに アイテムが見つかれば、 それ以降は実行されない インデックスが付かない列の フィルター処理は 5,000 件ずつ 4 回に分けて 処理が実行される M365VIRTUALMARATHON.COM #M365VM

35.

インデックス付きの列を組み合わせたフィルター 複数のインデックス付きの列を利用したフィルターは ふたつ目の列の条件ではインデックスが有効にはたらかない ひとつ目の フィルター M365VIRTUALMARATHON.COM ふたつ目の フィルター #M365VM

36.

インデックス付きの列を組み合わせたフィルター 複数のインデックス付きの列を利用したフィルターは ふたつ目の列の条件ではインデックスが有効にはたらかない ひとつ目のフィルターに 該当したアイテム数 ふたつ目のフィルターの動作 5,000 件以下 フィルターした結果が すぐに表示される 5,000 件より多い ひと目のフィルターの結果を 上位から 20,000 件ずつ評価する インデックス付きの列を 複数組み合わせたフィルター インデックスが効いていない M365VIRTUALMARATHON.COM #M365VM

37.

インデックス付きの列を組み合わせたフィルター アイテム アセロラ パパイア アイテム ひとつ目の フィルター アセロラ パパイア マルメロ マルメロ ・・・ ・・・ ・・・ ・・・ マンゴー アンズ ふたつ目の フィルター 30,000 件まで マンゴー 絞り込み アンズ ・・・ ・・・ ・・・ ・・・ ひとつ目のフィルターで 20,000 件以内に 絞れていると ユーザーには易しい ※ 理想は 5,000 件以下 上位 20,000 件を 対象に絞り込み 下位 10,000 件は、「その他のアイテムを読み込む」が クリックされた後にあらためて探索する モモ ライチ ・・・ M365VIRTUALMARATHON.COM #M365VM

38.

フィルターの順番を確認するには URLのパラメータ • ビュー上で操作を行った場合 • フィルターの条件は次のパラメーター • • • FilterField1, FilterValue1, FilterType1 FilterField2, FilterValue2, FilterType2 FilterField3, ビューの設定画面 • ビューとして保存した場合 • フィルターの設定の上の方で指定された列が ひとつ目のフィルター条件 • 番号の若い方がひとつ目のフィルター条件 M365VIRTUALMARATHON.COM #M365VM

39.

ひとつのインデックス付き列で並び替えとフィルター 同じ列で並び替えとフィルターを同時に行う場合 インデックスが有効にはたらかない インデックス付き列に 並び替えと フィルターを 同時に適用 M365VIRTUALMARATHON.COM #M365VM

40.

フィルター条件の AND と OR AND 条件 • 複数のインデックス付きの列を組み合わせたフィルターは、 ふたつ目の列の条件ではインデックスが有効にはたらかない • ビューの画面から操作した場合は AND 条件になる OR 条件 • フィルター順などに関わらず、インデックスが効かない • ビューの設定画面からのみ設定可能 M365VIRTUALMARATHON.COM #M365VM

41.

列インデックスが有効にはたらかないパターン • インデックスが付いていない列での並び替えやフィルター • 複数のインデックス付き列を組み合わせたフィルター • ひとつのインデックス付き列で同時に並び替えとフィルター • OR 条件のフィルター • できるだけこのパターンを避けて利用できると良い • モダンリストなら「その他のアイテムを読み込む」が利用できる M365VIRTUALMARATHON.COM #M365VM

42.

ここまでのまとめ 列インデックスが有効にはたらかないパターンを知っておくと ◎ インデックス付きの列を複数組み合わせたフィルター条件では、 条件の指定順に注意。ひとつ目の条件で出来るだけ対象を絞り込む モダンリストの「その他のアイテムを読み込む」を活用 M365VIRTUALMARATHON.COM #M365VM

43.

調査結果から導くリスト利用の極意 一、ビューは、必ずインデックス付きの列で並び替えせよ 一、目的のアイテムを探すには、フィルターを最大限活用せよ 一、フィルターは、できる限りインデックス付き列を利用せよ 一、複数のインデックス付き列を組み合わせたフィルターでは、 ひとつ目のフィルターで、できる限り数を絞り込むよう意識せよ 一、モダンリストの「その他のアイテムを読み込む」を活用せよ M365VIRTUALMARATHON.COM #M365VM

44.

フィルター ウィンドウを利用しよう フィルター ウィンドウ • 複数の値で絞り込んでいくのに便利 • 簡単に素早くアイテムを絞り込んで探すことができる [フィルターウィンドウに固定] でフィルターを追加 1 4 2 3 M365VIRTUALMARATHON.COM #M365VM

45.

MICROSOFT 365 VIRTUAL MARATHON 2022 MAY, 4. – 6. 2022 まとめ

46.

5,000 件問題は列インデックスとモダンリストで対処しよう SharePoint の 5,000 件問題は、負荷軽減のために今も存在する アイテム数が多くなった場合は、列インデックスの利用が大切 使いこなすためには、モダンリストの動作を理解する M365VIRTUALMARATHON.COM #M365VM

47.

MICROSOFT 365 VIRTUAL MARATHON 2022 ボーナストラック MAY, 4. – 6. 2022

48.

ルックアップ列(参照列) 大量のデータを対象としたルックアップも動作する 検索で探す ルックアップ対象列に インデックスを 作成しておく M365VIRTUALMARATHON.COM #M365VM

49.

ルックアップ列(参照列) 大量のデータを対象としたルックアップも動作する アイテム 検索で探す インデックス付き列の参照 A AAA AB ABA ABB BA • 参照先のアイテムを文字コード順にソート 25,000 件ずつ探索 AA • 「その他の結果」がクリックされるたびに 上から 25,000 件ずつ探索 • リストの最後まで同じ動作を繰り返し ポイント ・・・ ・・・ • 対象の列にインデックスを設定する XXX • 「その他の結果」の動作を理解する XYY M365VIRTUALMARATHON.COM XYZ #M365VM

50.

グループ化と合計 グループ化や合計の機能は 5,000 件を超えると上手く動作しない 5,000 件以下に フィルターしておくと グループ化できる M365VIRTUALMARATHON.COM #M365VM

51.

インデックス付き選択肢列への選択肢の追加 インデックス付きの選択肢列 • アイテム数が 20,000 件を超える場合、インデックス付きの 選択肢列への選択肢の追加ができなくなる • 選択肢を追加するには、対象列の列インデックスを削除する • 選択肢追加後に、再度インデックスを作成する • 実運用時には、遭遇しそうな動作 M365VIRTUALMARATHON.COM #M365VM

52.

権限の継承 サイト 上位の権限を 引継ぐ 権限の継承を中止する 100,000 件を超えた アイテムがあると 権限の継承の中止はできない (再継承もできない) リスト 上位の権限を 引継ぐ アイテム M365VIRTUALMARATHON.COM #M365VM

53.

5,000 件問題と関係なく動作する機能 Excel へエクスポート Power Query Access リンクテーブル リストに保存されたデータの集計や分析には、 Excel や Power BI、Access が利用できる M365VIRTUALMARATHON.COM #M365VM

54.

Power Apps の委任 委任できるはずの関数でデータ取得時にエラーになる場合がある M365VIRTUALMARATHON.COM #M365VM

55.

Power Apps の委任 委任するときはインデックスも同時に考える 委任対象の列に インデックスを 作成しておく M365VIRTUALMARATHON.COM #M365VM

56.

Power Automate のアイテム取得 リストからアイテムを取得するときにエラーになる場合がある M365VIRTUALMARATHON.COM #M365VM

57.

Power Automate のアイテム取得 しきい値のエラーが出た場合はインデックスを確認 操作対象の列に インデックスを 作成しておく M365VIRTUALMARATHON.COM #M365VM

58.

MICROSOFT 365 VIRTUAL MARATHON 2022 MAY, 4. – 6. 2022 まとめ

59.

このセッションで伝えたかったこと 5,000 件問題は正しく怖がろう モダンリストは良いぞ! M365VIRTUALMARATHON.COM #M365VM

60.

MICROSOFT 365 VIRTUAL MARATHON 2022 アンケートにご協力ください スピーカーおよびイベント への感想やご意見 https://forms.office.com/r/qCXhcZZUgU MAY, 4. – 6. 2022