C# と VB.NET の質問掲示板

わんくま同盟

ASP.NET、C++/CLI、Java 何でもどうぞ

C# と VB.NET の入門サイト

■92311 / 1階層)  DBのレコード追加
□投稿者/ WebSurfer (1904回)-(2019/09/10(Tue) 15:31:43)
No92306 (ぽんた さん) に返信

何を作っているのか(Windows Forms? WPF? ASP.NET Web Forms? その他?)と DataSet をどの
ように使っているのかの説明がないと想像で答えざるとえなくて、想像が間違っていると混乱を
招くだけということになりそうですが・・・

たぶん Windows Forms アプリであろうと想像して。

> データセットからDBを更新する処理で、
> SQLのINSERT文でExecuteNonQueryメソッドを使いレコードを追加したのですが、
> 連続で追加するときに、一度データセットでAcceptChangesメソッドを実行しないとエラーになります。

普通の DataSet の使い方をしているのであればそういうことにはならないはずです。

以下の記事の「非接続型のデータ更新」のセクションの図1と図2を見てください。

DB 設計者のための明解 ADO.NET 第 1 回
https://docs.microsoft.com/ja-jp/previous-versions/cc482903(v=msdn.10)

「SQLのINSERT文でExecuteNonQueryメソッドを使いレコードを追加」ということは必要ないこと
が理解いただけるでしょうか?


DataGridView などを UI として非接続型のデータ更新を行う場合は、

DataGridview ⇔ BindingSource/BindingNavigator ⇔ DataSet/DataTable ⇔ DataAdapter⇔ DB

・・・と言う構造にするのが普通です。

そのような構造にすれば、ユーザーが DataGridView を操作した結果は紹介した記事の図1にあ
るように DataSet / DataTable に反映されます。もちろん追加の結果もです。

編集作業が終了後、ユーザーが DataAdapter に Update メソッドをかければ、図2のように
DataAdapter から SQL が自動発行され、SQL Server のテーブルが更新されます。

DB が SQL Server の場合ですが、以下のチュートリアル、

10 行でズバリ !! 非接続型のデータ アクセス (ADO.NET) (C#)
https://code.msdn.microsoft.com/windowsdesktop/10-ADONET-C-cbfe7688

・・・のように Visual Studio のデータソース構成ウィザードを利用して型付 DataSet +
TableAdapter を作って、それを利用してアプリを作ると、上に書いた、

DataGridview ⇔ BindingSource/BindingNavigator ⇔ DataSet/DataTable ⇔ DataAdapter⇔ DB

・・・と言う構造、すなわち以下のページの図のような構造のアプリが、ほとんど自分で
コードを書くこと無しに作れます。

Windows フォーム アプリケーションでのデータへの接続
https://docs.microsoft.com/ja-jp/previous-versions/wxt2cwcc(v=vs.120)

上に紹介したチュートリアルは 2 つのテーブルを階層更新するために少々複雑になってい
ますが、単一テーブルですともっと簡単で、操作に慣れると以下のようなアプリが 5 分も
かからず作れるはずです。

自力で一からコードを書く場合のような種々の問題に悩むことはなくなり、開発工数は
激減するはずです。保守工数も減るはずです。

興味があればお試しください。
編集キー/

前の記事(元になった記事) 次の記事(この記事の返信)
←DBのレコード追加 /ぽんた 返信無し
 
上記関連ツリー

DBのレコード追加 / ぽんた (19/09/10(Tue) 14:57) #92306
Re[1]: DBのレコード追加 / 魔界の仮面弁士 (19/09/10(Tue) 15:57) #92314
│└ Re[2]: DBのレコード追加 / ぽんた (19/09/10(Tue) 16:06) #92315
│  └ Re[3]: DBのレコード追加 / 魔界の仮面弁士 (19/09/10(Tue) 16:12) #92317
DBのレコード追加 / WebSurfer (19/09/10(Tue) 15:31) #92311 ←Now

上記ツリーを一括表示 / 上記ツリーをトピック表示
 
上記の記事へ返信