11

DataTable にデータを入力DataAdapter.Fill(DataTable);してから、DataTable の行を次のような簡単なDataTable.Rows[0]["Name"] = "New Name";方法で変更した場合、これらの変更をデータベースに簡単に保存するにはどうすればよいでしょうか? 私は呼び出すことができると思っDataAdapter.Update(DataTable);ていましたが、TableAdapter(?) でのみ機能することを読みました。

4

2 に答える 2

33

他の誰かがこれを行う方法を知る必要がある場合に備えて、実際に役立つ回答を次に示します。

string selectStatement = "SELECT * FROM Contact";
System.Data.DataTable dt = new System.Data.DataTable();
SqlConnection conn = new SqlConnection(System.Configuration.ConfigurationManager.ConnectionStrings["MyConnectionString"].ConnectionString);
conn.Open();
SqlDataAdapter sqlDa = new SqlDataAdapter();
sqlDa.SelectCommand = new SqlCommand(selectStatement, conn);
SqlCommandBuilder cb = new SqlCommandBuilder(sqlDa);
sqlDa.Fill(dt);
dt.Rows[0]["Name"] = "Some new data here";
sqlDa.UpdateCommand = cb.GetUpdateCommand();
sqlDa.Update(dt);
于 2013-03-08T12:26:11.937 に答える