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

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

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

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

Visual Studio

Microsoft Visual StudioはMicrosoftによる統合開発環境(IDE)です。多種多様なプログラミング言語に対応しています。

Q&A

解決済

3回答

1060閲覧

【VisualStudio】C# Windows用アプリ開発でのデータ保存について

退会済みユーザー

退会済みユーザー

総合スコア0

C#

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

Visual Studio

Microsoft Visual StudioはMicrosoftによる統合開発環境(IDE)です。多種多様なプログラミング言語に対応しています。

0グッド

1クリップ

投稿2018/09/20 02:07

編集2018/09/20 03:50

前提

社内で利用できるソフトを作ろうと思っています。
タスクやその他、管理用のソフトです。
期間を指定し、TODOリストや進捗等の管理を行います。
以前質問させて頂き、結局データ保存にはSQLiteを利用することにしました。
ベストアンサー変更できないのが申し訳ないです。

発生している問題・不明点

例えば、「2018年8月」というデータを作成したとして、
新規作成後「2018年9月」というデータを名前を付けて保存出来るようにしたいです。
1年ごとにファイル自体を変えたいことがあると思うので、別名でファイル保存したいです。

Excelの例で言えば、xlsファイルみたいに
名前付けて保存でき、ファイルを開くことが出来るようにしたいと思っています。

どうやって保存していくのが良いのでしょうか?
お勧めの保存形式等はありますでしょうか?

考えていること

・主データベースを作っておき、そこから出力して新しいデータベースを作成して保存する
(それを読み込むことで、特定データのみの情報を読んだり出来る)
(ファイル名テーブルに、ファイル名とデータベース名を記載しておきそれを読み出す)
→主データベースの量が膨大にならないか?
既にパソコン上から消したもの等判断が難しそう
1日1個、毎日別名で保存する利用方法をしていたら
データベースいっぱいいっぱいになりそう。
削除も面倒そう。

・データベース自体を日本語の独自名で保存出来るようにする
→難しそう

補足情報(FW/ツールのバージョンなど)

Microsoft Visual Studio2017

追記 9/20 12:44

データベースは必要最小限にとどめたいと思っています。
ユーザーが好きなように変更できる必要もあります。

ユーザーAは1ヶ月ごとにファイルを作り直したい。
読み直しもそれで行いたいというのであれば、別名でファイルを保存できるようにし、容易に開くことが出来るようにします。
ユーザーBは1年ごとにファイル名を変更して保存したい。(余分なデータは要らない)
余分なデータが追加されていくたびにまた、最小限ではないとメンテも大変になります。

データベースで「このユーザーは1ヵ月だけのデータを呼び出したいのか」等
そういうフラグを立てるのは面倒です。プログラム自体も最小限にしたいのです。
別途保存したデータをどのように使うかというと、通常のDBと同じ通りに読み込むだけです。

不要なものは不要なものとして破棄したいですし、1つのDBに頼るのは好ましくありません。
別名でファイル保存でき、それを読み出すことができるようなものが理想です。

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

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

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

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

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

Zuishin

2018/09/20 03:06

必要ありますか? データベース自体がデータの検索をするためのもので、年月のクエリを投げることで容易に求めるデータを得ることができます。別途保存したデータをどのように使うのかを「詳しく」(三行で書くのはありません。具体例を複数挙げて書いてください)書けばそれに特化した保存の仕方を考えた回答がつくのではないかと思います。
Zuishin

2018/09/20 03:08

つまるところこの質問は、データをどの形式でエクスポートしたら一番使い易いかという質問になります。用途がわからなければ答えようがありません。
退会済みユーザー

退会済みユーザー

2018/09/20 03:43

うーん……データベースを膨大にしていくのは避けたいです。1発で全データが消えてしまうという可能性も避けたいです。そのため、別名で保存したいと思っているんです。とりあえず追記します。
yukihisa

2018/09/20 03:58 編集

「データベースを膨大にしていく」の意味がよくわからないのですが、結局他のDBを作成しても保存するのであれば同じですよね。むしろファイル等を作成していく方がストレージを圧迫するように感じますが。データが飛ぶ云々に関しては日次バックアップを取っておけばいい話ではないでしょうか・・・?とはいえ、申し訳ありませんがそもそも「DBに関する知識」が壊滅的に足りていないように見受けられます。データベースはあくまでもデータの管理、検索をするものであり、出力するのであれば別途プログラムを組むなりしないといけません。データを検索・出力した後の話は各ユーザのローカルの話になりますのでデータベースが肥大化するという話にはなり得ません。
退会済みユーザー

退会済みユーザー

2018/09/20 05:10

ありがとうございます。データベースがどのくらいの量OKなのか等必要知識に欠けているとは思います。すみません。日々200件程度のデータ(200行、20列程度)を書き込んでいった場合、何年経っても動作は大体同じ速度で動くのでしょうか?
yukihisa

2018/09/20 05:27

サーバーのスペック等にもよりますが、その答えは「teratail」が快適に使える時点で出ていると言っても良いでしょう。細かい数字を気になさるのなら https://okwave.jp/qa/q8943090.html この辺りを見てみたら少しは安心するのではないでしょうか。最初にきちんと構成しておけばストレージの要領が許す限り、億単位のデータでも問題ないですよ。
Zuishin

2018/09/20 06:23

日々たった 200 件ですか? 多分孫子の代まで同じ速度で(むしろ技術の進歩を考えるともっと速く)使えると思いますよ。
guest

回答3

0

投稿2018/09/20 03:23

kiichi54321

総合スコア1984

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

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

退会済みユーザー

退会済みユーザー

2018/09/20 03:37

表題にある「データ保存について」の話に JSON が出てくるのはどういう訳ですか?
退会済みユーザー

退会済みユーザー

2018/09/20 03:40

データベースの内容をJSON形式で保存するのがベスト、ということでしょうか?
Zuishin

2018/09/20 03:45

検索性だけが用途なのであれば別途保存しないのがベストだと思います。
退会済みユーザー

退会済みユーザー

2018/09/20 04:40

JSON でデータを保存するのがベストなんてことはまず絶対と言っていいほどありません。何か見当違いがあるようで、話が噛み合ってないようです。
guest

0

しっかり考え直してみたら
「別名保存したい」という意味も良く分からなくなってきました。
過去のデータは過去のデータでテーブルわけすれば良いし
データもそこまで大きくならないと思うので、
同じDBを利用仕様と思います。

投稿2018/10/12 03:23

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

Zuishin

2018/10/12 03:30

ベストアンサー頂きましたが、そういう結論なら私の考えとは一致しますが実際の回答の趣旨とは全く違うので、後で見る人のことを考えると自己解決の方がいいと思います。
guest

0

ベストアンサー

おそらくデータベースについて誤解が多くあると思いますが、それを無視して言うなら、「データを欠損なく保存できてどこにでもあるアプリで開けるなら何でもいい」ということになりませんか?

kiichi54321 さんの仰るような JSON ならテキストなのでメモ帳で開けます。
また XML や HTML や CSV も同様です。
この中のどれであっても要件は満たすと思います。

データの構造によりますが Excel で開くことのできる CSV が最も見易く編集もし易いと思います。

投稿2018/09/20 04:01

編集2018/09/20 04:02
Zuishin

総合スコア28656

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

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

退会済みユーザー

退会済みユーザー

2018/09/20 05:07

ありがとうございます。 すみません、データベースはざっくり分かるのですが アプリ独自の拡張子で保存するようなものは作れないかと考えています。 Tama5というフリーソフトであれば、xhc5という拡張子でデータが保存されるような感じです。 確かにデータベースさえあれば問題ないですし、バックアップを取れば問題ないというのもありますが、毎回起動時に必要情報のみ出力するようフィルターをかけるのも面倒だなと思ったので…。 CSVにしてしまうとExcelとかが既定ソフトになってしまっていると思うので避けたいです。 やはりデータベースがベストでしょうか。
Zuishin

2018/09/20 06:18

Excel が悪い理由がわかりませんが、CSV の拡張子を txt にするとメモ帳が既定ソフトになります。 またほかの表計算ソフトでも CSV が読めないものはありません。
Zuishin

2018/09/20 06:20

それから拡張子をアプリ独自のものにして中身 CSV でも全然構いません。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問