Firestore でのフィードとフォローのシステム構造の最適化
ソーシャル ネットワーク アプリのフィードとフォローのシステムを設計する場合、次のことが重要です。パフォーマンスのボトルネックを防ぐためにスケーラビリティを考慮してください。これに対処するために Firestore でデータベースを構造化する方法は次のとおりです:
初期リレーショナル スキーマ
現在の Firebase Realtime Database スキーマには次のものが含まれます:
Firestore データベースの構造
Firestore でこの構造を最適化するために、コレクションを利用する非正規化アプローチを提案します:
非正規化の利点
データを非正規化することで、コストのかかる結合の必要性がなくなり、クエリのパフォーマンスとスケーラビリティが向上します。
ユーザーフォローのクエリ
ユーザーのリストに続いて、次のクエリを実行できます。
CollectionReference userFollowingRef = rootRef.collection("following/" + uid + "/userFollowing");
ユーザーの投稿のクエリ
ユーザーの最新の投稿を取得するには、次のクエリを実行できます。
Query query = rootRef.collection("posts/" + uid + "/userPosts").orderBy("date", Query.Direction.DESCENDING).limit(3);
フィード取得の最適化
ユーザーのフィードを効率的に取得するには、次の点を考慮してください。
この改訂された構造は、初期設定のスケーラビリティの問題に対処します。スキーマを使用すると、Firestore で大量のフォロワーと投稿を効率的に管理できるようになります。
以上がFirestore はフィードを最適化し、システムのスケーラビリティを追跡するにはどうすればよいでしょうか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。