一部のデータベース テーブルのモデリングで次の問題が発生しました。
いくつかのコンテスト (それぞれに一意の ID を持つコンテスト テーブル) があり、各コンテストでプレイヤーにいくつかの賞品を与えるとしましょう。3 つの賞 (金、銀、銅) があり、それぞれにタイトル、ロゴ画像、および将来的には他のデータが含まれます。
ただし、一部のコンテスト (コンテスト ID に基づく) では、一部の賞品のロゴまたはタイトルをカスタマイズできるようにしたいと考えています。賞品がカスタマイズされていない場合は、デフォルト値がいくつかあるだけです。
もう 1 つの要件は、任意のコンテストで金メダルを獲得したすべてのプレーヤーを選択できるようにすることです (基本的に、カスタマイズは無視します)。
これまでの私の解決策は次のとおりです。
賞品テーブルで、主キーに加えて、半固有の別のキーを追加します。カスタマイズされたすべての金メダルには異なる主キーがありますが、同じ準一意キー (タグと呼びましょう) を共有します。このようにして、賞品の任意の列をカスタマイズできますが、すべての金賞受賞者を選択する機能を維持できます (共通タグを使用)。
賞品テーブルを 2 つに分割します。不変データと可変 (カスタマイズ可能) データです。このようにして、金メダルの一意の主キーを 1 つ持つことができますが、変更可能なデータ テーブルでは、その ID が複数の行で見つかる可能性があります。このテーブルでは、主キーは賞品 ID とコンテスト ID の複合になります。
パフォーマンスと、賞品に他の情報を追加する際の柔軟性の点で、どのソリューションが最も気に入っていますか? 別の方法を提案しますか?