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

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

新規登録して質問してみよう
ただいま回答率
85.50%
C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

.NET Framework

.NET Framework は、Microsoft Windowsのオペレーティングシステムのために開発されたソフトウェア開発環境/実行環境です。多くのプログラミング言語をサポートしています。

Q&A

解決済

3回答

3269閲覧

データベースとdatファイル、読み書きが早いのはどっちですか?

nyahonyaho

総合スコア83

C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

.NET Framework

.NET Framework は、Microsoft Windowsのオペレーティングシステムのために開発されたソフトウェア開発環境/実行環境です。多くのプログラミング言語をサポートしています。

0グッド

0クリップ

投稿2016/08/24 05:13

0.4秒ごとに稼働情報ログを書き込んでいく、機械制御用デスクトップアプリ(ATMの操作画面みたいなもんです)を作っています。

datファイルを0.4秒ごとにファイルオープンしてログ(41バイト/1レコード)を書き込むやり方は実績があるのですが、datファイルの中身は当然見にくいのでデーターベースを採用して作り直そうと考えてます。

が、データベースを採用したはいいが0.4毎の処理に追いつけなかったらどうしようと悩んでます。

よって、掲題の質問になるのです。

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

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

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

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

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

guest

回答3

0

書き込みはファイル単体のほうが速いです。
DBは最終的にファイルに書くとした場合、当たり前ですが当然オーバーヘッドが入ります。

データをどのように使うかで、どう設計するか考えていきましょう。
データベースにも得意/不得意色々あります。

どのように使うかはわかりませんが、後で一定範囲のデータを参照したい、等であれば
時系列に強いデータベースを選択しましょう。

投稿2016/08/24 06:46

moonphase

総合スコア6621

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

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

0

ベストアンサー

データファイルのお尻にを追記するだけであれば、ローカルのストレージ上にあるファイルに直接書き込むのが最速だと思います。
大分前に試した時は以下の順で早かった記憶があります。
ローカルファイル > ローカルの組込型DBMS > ローカルのネットワーク型DBMS > 別サーバ上のネットワーク型DBMS > ファイルサーバ上のファイルを読み書き

何が最速かはともかく、0.4秒に一度の追記ならどんなDBMSを使っても問題ないとは思います。

投稿2016/08/24 05:39

hihijiji

総合スコア4150

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

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

nyahonyaho

2016/08/24 06:54

とりこし苦労なわけですね・・・速い順のリストまで作っていただきありがとうございます。
guest

0

datファイルというのはふつうのテキストファイルということでよろしいですか?
それなら圧倒的にデータベースのほうが早いです。
サーバーのスペックやデータベースシステムにもよりますが、
データベースであれば1秒で100レコードとかでも余裕で処理できます。

投稿2016/08/24 05:27

jm1156

総合スコア866

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問