質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.37%
MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

Q&A

解決済

3回答

337閲覧

テーブルの列が多い場合の対応について

HoshiMizu

総合スコア31

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

0グッド

0クリップ

投稿2024/09/06 09:47

ある計測結果をDBに格納しようとしていますが、データ項目が約500件ほどあります。
この場合、どのようにテーブルを作成したほうが良いとおもいますか?

データ例)
ID
型式
シリアル
計測A1~10
計測B1~10
計測C1~10


1)全ての項目分、列を作成する。
列数がものすごいことになる。
1レコードで全ての情報が取れる。

2)EAVを使用する。
結果_値テーブルを設けて、そこにデータを格納する。
種別, 値
A1 1000
A2 2000
B1 1500
列数が少なくすむ。
データを取得する際、条件付けが大変。

その他、やり方があれば、教えて頂ければ幸いです。

宜しくお願いします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答3

0

ベストアンサー

色々な意見がある話だと思いますし、ユースケースにも寄るとは思うので、絶対的な回答ではなく個人的な意見としてご参照ください。

計測機器や計測項目が絶対に不変であるならば(1)を、
今後変更する可能性が少しでもあるならば(2)を選択します。

また、値を参照する際に各カラムのデータを別々に参照することが多いならば (2)を、
常に一括参照するならば(1)を選択すると思います。

ご参考になれば幸いです。

投稿2024/09/06 10:16

toge_

総合スコア226

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

HoshiMizu

2024/09/10 01:15

ご回答ありがとうございます。参考に致します。
guest

0

MySQLは詳しくありませんが、繰り返し部分を配列にすることでカラム数500を50に減らすことができるようにおもいます。
具体的には「1~10」の部分をJSONデータ型とする。
そのうえで今後種別が、増減するなら(2)を、未来永劫固定なら(1)。

投稿2024/09/09 01:21

shiketa

総合スコア4041

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

HoshiMizu

2024/09/10 01:15

ご回答ありがとうございます。参考に致します。
guest

0

単純に言えば、すべて(もしくはほとんど)のデータが埋まっているのであればそのまま全データをテーブルにおさめるのが最も効率の良いデータ管理方法です
また集計単位つまりA,B,Cというグルーピングになにか意味があるのかによります。たとえばAの集計とBの集計を同時に行うことがない(グループごとに完結している)なら、A,B,C・・・をそれぞれ外だしにして集計後連結するような方法も考えられますが、命題の条件提示が不十分なので判断つきません。

投稿2024/09/09 00:52

yambejp

総合スコア116468

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

HoshiMizu

2024/09/10 01:15

ご回答ありがとうございます。参考に致します。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.37%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問