Обновление базы данных из DataSet с несколькими таблицамиC#

Место общения программистов C#
Ответить
Anonymous
 Обновление базы данных из DataSet с несколькими таблицами

Сообщение Anonymous »

У меня есть приложение с редактором нескольких DataTable, которые хранятся в DataSet, который я загружаю через DataAdapter. Моя цель — обновить базу данных со всеми изменениями во всех таблицах. Я подумал об использовании того же DataAdapter, который использовался для загрузки данных с помощью построителя команд, как если бы это был один DataTable.
Вот как я загружаю набор данных:

Код: Выделить всё

using (SqlConnection con = new SqlConnection(ConnectionString))
{
con.Open();
var query = "SELECT * FROM Parameters;
SELECT * FROM Status;
SELECT * FROM Commands;";

var selectCommand = new SqlCommand(query, con);

DataAdapter = new SqlDataAdapter(selectCommand);
DataAdapter.AcceptChangesDuringFill =
DataAdapter.AcceptChangesDuringUpdate = true;

DataAdapter.TableMappings.Add("Table", "Parameters");
DataAdapter.TableMappings.Add("Table1", "Status");
DataAdapter.TableMappings.Add("Table2", "Commands");

DataAdapter.Fill(DataSet);
}
После того, как пользователь редактирует данные в различных таблицах, вызывается обновление, в котором я использую тот же DataAdapter с запросом SELECT, используемым для загрузки данных в первую очередь и CommandBuilder. У меня проблема заключается в том, что при этом построитель команд «обнаруживает» только первую таблицу и создает запросы на обновление только для указанной таблицы.

Код: Выделить всё

using (SqlConnection con = new SqlConnection(ConnectionString))
{
con.Open();

try
{
DataAdapter.SelectCommand.Connection = con;

SqlCommandBuilder builder = new(DataAdapter);
DataAdapter.Update(DataSet);
}
catch (SqlException)
{
}
}
Есть ли возможность сделать так, как я задумал, или мне придется изменить подход?

Подробнее здесь: https://stackoverflow.com/questions/784 ... ple-tables
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C#»