私が働いている学校の授業観察システムを書いています。
データベース構造は次のようになります。

私は現在、Observationsテーブルの入力フォームを開発しており、そのフィールドのかなりの数にチェックボックスが必要です。たとえば、Focusフィールドは任意の 12 個のオプションにすることができます。PositiveおよびNegativeフィールドはそれぞれ、ほぼ 20 の任意の数のオプションにすることができます。
上の画像では、 'd 配列VARCHARを許可していました。serialize
ただし、特に、データの半複雑な分析を行いたい場合があることを考えると、これが最善のルートであるかどうか疑問に思い始めています(これには、スタッフの各メンバーが持っている属性top 5 staff for a specific positive attribute such as behaviourの数を数えることが含まれます)テーブル内behaviourのPositiveフィールド)。Observations
ここに 2 つの質問があります。
- 追加のテーブルを使用する必要がありますか?
Focus最初のテーブルには 3 つのフィールド(IDキーと自動インクリメント)Observation_IDとFocus_ID. は、 または と という 2 つのフィールドを持つFocus_ID別のテーブルと関連付けられます。/ には 2 つのテーブル、 /には 3つのテーブルが必要です(オプションは同じですが、ロギングは異なります)。fociiFocus_IDTitleFocusPositiveDevelopment Observationsこれらの追加のデータベース テーブルを使用すると、関連するすべてのfocuses、positivesおよびを含むテーブルから情報を取得しようとすると、SQL ステートメントはどのようになりdevelopmentsますか?
前もって感謝します、