格納するデータの数が決められていない場合のテーブルのつくりかたについて質問です。
予め入力項目数が決定している時は、その数に合わせて列をつくればいいのですが、大きい入力用テキストボックスが一つだけあって、ユーザにaaa,bbb,ccc,123といったようにデータを入力してもらい、カンマで区切られた一つひとつのデータをデータベースに格納するといったことをしたい場合、データが一つだけの場合も100を越えるような場合もあるので、テーブルをどのように構築すればいいのか困っています。
アドバイスお願いいたします。
A 回答 (3件)
- 最新から表示
- 回答順に表示
No.3
- 回答日時:
KELU_NKUNさんのイメージでは、こんなテーブルを作りたいということでしょうか?
test_table
user_id, value1, value2, value3, value4
----------------------------------------
1, aaa, bbb, ccc, 123
2, xxx, eee, kkk,
上記テーブル構造では入力値の数が4つまでに対応してますが、
もしユーザーによってデータ数が5つ以上となる場合は無理です。
5つ以上のデータ数に対応する為には、ユーザーの入力値の最大データ数を決めておかなければなりません。
最大データ数を100とするなら、value1~value100までのフィールドを作っておけばいいだけです。
もし最大データ数を決めておけない場合は、
ユーザーデータ格納時に、現在のvalueフィールドの数と、今から格納するデータ数の差を計算して
足りないフィールド数がある場合は、その分のフィールドを追加⇒その後ユーザーデータを格納。
といったことをすれば大丈夫でしょう。
ただ、こういった構造にしてしまうと、データを引っ張って来るときなどが面倒だと思います。
なので、行を増やしていく方法が良いと思います。
さっきのテーブルを行を増やす方法にするとこんなイメージになります。
test_table
user_id, value
----------------------------------------
1, aaa
1, bbb
1, ccc
1, 123
2, xxx
2, eee
2, kkk
No.1
- 回答日時:
ここのカテゴリ通り、RDBMSはMySQLなのでしょうか?
RDBMSにより異なりますが、表を構成する列数の上限は、そんなに多くありません。512だったり1024とかです。
また、カンマ区切りといったデータを1列に格納するというは、柔軟な操作性を提供してくれるSQLを、わざわざ使いにくくし、改造がしにくく、性能を上げたりといった工夫ができなくなる場合が多いです。
ただ、列数が多いと、性能が極端に悪くなるRDBMS、バージョンもあるため、大規模なシステムで性能を出したい場合、表定義上は1個の列を、アプリ側で複数フィールドの値として操作するといったことを敢えて行う場合もあります。
しかし、KELU_NKUNさんが考えてるのは、そういったシステムではないですよね?
ちゃんと正規化し、列で管理するのでなく、行で管理することを考えましょう。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
- ・ゆるやかでぃべーと タイムマシンを破壊すべきか。
- ・歩いた自慢大会
- ・許せない心理テスト
- ・字面がカッコいい英単語
- ・これ何て呼びますか Part2
- ・人生で一番思い出に残ってる靴
- ・ゆるやかでぃべーと すべての高校生はアルバイトをするべきだ。
- ・初めて自分の家と他人の家が違う、と意識した時
- ・単二電池
- ・チョコミントアイス
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
カラム名を取得
-
ACCESSで容量が50MBになった...
-
オラクルのエクスポートについて
-
htmlコードで書かれた表にphpで...
-
テーブルで一番古いレコードだ...
-
MySQLのDB内容をWEB上に表示す...
-
「クリップボードにコピーされ...
-
このISAMでは、リンクテーブル・・
-
重複クエリを使ったデータ削除
-
クエリとパススルークエリを作...
-
MySQLの容量の削減の仕方
-
仕事のミス:本番データの削除→...
-
left joinなどで結合対象のレコ...
-
MySQLである項目の値の種類を求...
-
sql serverのテーブルレイアウ...
-
男性と2人で飲食店に行きテーブ...
-
お金持ちのテーブル
-
件数とデータを同時に取得する...
-
MACアドレス見えない
-
「テーブルに座って……」という...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Accessでデータシートに同じデ...
-
Accessのテーブルデータを一気...
-
テーブルで一番古いレコードだ...
-
Oracleで上書きImportはできま...
-
このISAMでは、リンクテーブル・・
-
アクセス レコードセットを更...
-
ビューのソートについて
-
マテリアライズドビューとスナ...
-
処理の途中で停止させ、再開さ...
-
MS Accessを共有した際にファイ...
-
構文エラー : 演算子がありませ...
-
ORA-01401が表示され、データが...
-
accessでレコード更新直後の反...
-
重複クエリを使ったデータ削除
-
Accessでの稼働日数計算の方法
-
住所のDBテーブル、マスターの...
-
同一テーブルのデータを参照し...
-
ERROR1062:Duplicate entry.......
-
ACCESSで容量が50MBになった...
-
複数のテーブルを参照するselec...
おすすめ情報