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

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

ただいまの
回答率

88.92%

DBが必要になるのはどんな場面でしょうか?

解決済

回答 6

投稿

  • 評価
  • クリップ 1
  • VIEW 841

javacurry

score 50

例えばJavaで変数に名前、年齢、テストの点数を配列に入れてしまえば取り出したり書き換えたりできる気がします。JavaとDBの連携を覚えればいろいろできるようになるらしいのですが、そのいろいろが想像できません。例えば個人で作るような身近で簡単なプログラムにDBが必要になる場面はあるのでしょうか?

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 6

checkベストアンサー

+6

配列のデータはプログラムを終了すれば消えてしまいますが、データベースに保管すればディスクに保管されるので、永続的に利用可能となります。

また、配列はメモリ容量の加減で最大数は限られてきますし、データを探すときも1つ1つ探していくしかありませんが、データベースの場合は「巨大なデータの一部だけ取ってくる」「インデックスを付けて高速に検索を行う」など、巨大なデータを扱うのに長けています。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/05/28 21:04

    みなさんのアドバイスのおかげでDBを使う場面が見えてきました。使う機会がないかもしれませんが同時に興味もわいてきました。

    キャンセル

+3

常に必要ではない巨大なデータを扱う場合とか、そのデータを他のシステムと共有する場合とか、プログラム終了後もデータを保持したい場合などに有効ですね。
似たようなことはテキストファイルでもバイナリ書き出しでもできますが、DBはそういったもののフレームワークのように振舞って、面倒なことを全部代行してくれます。
データへのアクセス制限などのセキュリティ、高速な目的データの抽出、効率の良いデータ保持、インターフェースの統一、etc...

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

+3

プログラムの起動期間を超えてデータを保存することを「データの永続化」なんていったりします。永続化したデータ量の多寡に従いDBにする方がよいというのはmaisumakunさんがおっしゃるとおりと思います。

データの永続化にはDBを用いるかファイルへのシリアライズ・デシリアライズで行うかの選択があると思います。個人で作る小規模なアプリケーションでは後者で充分なことも多いです。プログラム終了前にファイルへ保存しプログラム起動時にファイルから読み込めばよいですし、「扱うデータがプログラムの実行空間の中に全て保持しても問題ないくらいの量」ならプログラム内での扱いも単純です。

今日の普通のPCですと例えば数メガ~数十メガバイト程度までならメモリーへ読み込んでもそれほど問題にはならないでしょう。それくらいの量であれば入出力にかかる時間はいくら多く見積もっても数秒前後です。例えば日本全国の郵便番号から住所を自動変換するような機能を作ったとして郵便局から提供されているcsvファイルを読み込むとするとそのくらいのデータ量になります。

プロの方が作るプログラムは「そういったデータよりもはるかに巨大なデータを扱える」「素早く起動し高速にデータ処理できる」「個々のプログラムの力を借りなくてもDBMSの機能を使ってデータそのものをメンテナンスできる」といったことを当たり前の条件とするでしょうから普通にDBが出てくると思います。

しかしアマチュアが個人で作るアプリであれば、DBMSをアクセスするプログラムよりはファイルによる永続化の方が簡単なため、よほどの「信頼性、データ量、可用性」を望まない限りはファイルへの永続化で間に合わせることが多いのも事実です。色々なアプリを作っているうちに、いつか「うーん、これじゃぁ遅いなぁ」と感じたとき、それがDBを利用するときだと思います。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

+2

例えばCSVファイルにNO,国語、算数、理科、社会のデータが入っているとします。
プログラムを作ってデータを読み込み、配列に入れますよね。
国語の先生が国語のデータをいじりたい時そのプログラムでできますか?(組み込んでしまうのですか?)
算数と理科は同じ先生だから2つ同時に入れたいとした時対応できますか?
人が増えてもう1行作るときはどのようにしましょう。

すべてCSVファイルに書き出せばいろいろなプログラムでアクセスできるのではないでしょうか?
配列に入れてしまったら他のプログラムから触れません。

さて、CSVファイルですが、ひとり(1つのプログラム)専用になります。
同時共用するとCSVファイルだと壊れちゃうんですね。

ファイルを壊さないようにでも複数人がデータを操作できるにはどうしたら良いでしょう?
そこをすべて解決したのがDBなんです。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

+2

ひとくちにDB(Database)といってもピンからキリまでありますね。
目的にもよりますが、個人でちょっとしたプログラムを作るなら
DBなど必要としないことが多いような気がします。

で、DBを使うとなにがうれしいかというと、まずはSQLという
(わりと)共通的な書式でデータがアクセスできること。
スケールアップする際はDB関連を強化すればオッケー的な?
もちろん、そんな単純な話ばかりではないですけどね。

あと、たまったデータを他のプログラムからも利用できる。
もしくは、他の言語で作り直そうみたいなときも(わりと)
少ない手間で対応できちゃったり?

例えば、テキストファイルに保存して云々するより
場合によってはDBを利用する方がお手軽だったり
することもありますな。
もちろん、もろもろの条件によってどのような造りに
するかは決まってきます。
なので、一般的な話でいいわるいってのは判断つかないんス。(^_^;

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

+1

例えばJavaで変数に名前、年齢、テストの点数を配列に入れてしまえば取り出したり書き換えたりできる気がします。

そのプログラムがずっと動いていて、マシンも再起動などしないのであればそうです。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

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

  • ただいまの回答率 88.92%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る