50,000 項目を含む 1 つのテーブルがあり、各レコードの PK が一意の番号であるとします。これらのアイテムの半分は、プロパティ「published」が「1」に設定され、残りは「0」に設定されています。
ほとんどの場合、ハッシュ キーを使用して個々のアイテムを取得しますが、公開済み = 1 または 0 (理想的にはページ分割されたバッチ) のすべてのアイテムを取得できるようにしたい場合もあります。
「published」属性に PK を指定した GSI を作成できますが、値ごとに 25,000 レコードが存在することになります。PK はこれよりも一意である必要があるため、これは悪いことだと理解しています (これを理解した場合はお知らせください)。間違って)。
公開済み/非公開用に別々のテーブルを持つこともできますが、個々のアイテムを取得するという私の一般的なユースケースでは、アイテムが公開されているかどうかを事前に知る必要はありません (また、Amazonは、適切に設計されたアプリには通常 1 つしかないと言います)テーブル)。
アドバイスや提案をいただければ幸いです。