Читать «ЯЗЫК ПРОГРАММИРОВАНИЯ С# 2005 И ПЛАТФОРМА .NET 2.0. 3-е издание» онлайн - страница 598

Эндрю Троелсен

private static void InsertNewCar(SqlDataAdapter dAdapter) {

 // Сбор информации о новой машине.

 …

 // Формирование SQL-оператора Insert и подключение к DataAdapter.

 string sql = string.Format("Insert Into Inventory" +

  "(CarID, Make, Color, PetName) Values" +

  "('{0}', '{1}', '{2}', '{3}')",

  newCarID, newCarMake, newCarColor, newCarPetName);

 dAdapter.InsertCommand = new SqlCommand(sql);

 dAdapter.InsertCommand.Connection = cnObj;

 // Обновление таблицы Inventory с учетом новой строки.

 DataRow newCar = dsCarInventory.Tables["Inventory"].NewRow();

 newCar["CarID"] = newCarID;

 newCar["Make"] = newCarMake;

 newCar["Color"] = newCarColor;

 newCar["PetName"] = newCarPetName;

 dsCarInventory.Tables["Inventory"].Rows.Add(newCar);

 dAdapter.Update(dsCarInventory.Tables["Inventory"]);

}

После создания объекта команды он "подключается" к адаптеру с помощью свойства InsertCommand. Затем в DataTable таблицы Inventory добавляется новая строка, представленная объектом dsCarInventory. После добавления DataRow в DataTable адаптер выполнит SQL-команду, обнаруженную в свойстве InsertCommand, поскольку значением RowState этой новой строки является DataRowState.Added.

Установка свойства UpdateCommand

Модификации метода UpdateCarPetName() оказываются приблизительно такими же. Просто создайте новый объект команды и укажите его для свойства UpdateCommand.

private static void UpdateCarPetName(SqlDataAdapter dAdapter) {

 // Сбор информации об изменяемой машине.

 …

 // Форматирование SQL-оператора Update и подключение к DataAdapter.

 string sql = string.Format("Update Inventory Set PetName = '{0}' Where CarID = '{1}'", newPetName, carToUpdate);

 SqlCommand cmd = new SqlCommand(sql, cnObj);

 dAdapter.UpdateCommand = cmd;

 DataRow[] carRowToUpdate = dsCarInventory.Tables["Inventory"].Select(string.Format("CarID = '{0}'", carToUpdata));

 carRowToUpdate[0]["PetName"] = newPetName;

 dAdapter.Update(daCarInventory.Tables["Inventory"]);

}

В данном случае, когда вы выбираете строку (с помощью метода Select()), для RowState указанной строки автоматически устанавливается значение DataRowState.Modified. Другим заслуживающим внимания моментом здесь является то, что метод Select() возвращает массив объектов DataRow, поэтому вы должны указать, какую именно строку требуется изменить.

Установка свойства DeleteCommand

Наконец, вы имеете следующую модификацию метода DeleteCar().

private static void DeleteCar(SqlDataAdaper dAdapter) {

 // Получение номера удаляемой машины.

 …

 string sql = String.Format("Delete from Inventory where CarID = '{0}'"; carToDelete);

 SqlCommand cmd = new SqlCommand(sql, cnObj);

 dAdapter.DeleteCommand = cmd;

 DataRow[] carRowToDelete = dsCarInventory.Tables["Inventory"].Select(string.Format("CarID = '{0}'", carToDelete));

 carRowToDelete[0].Delete();

 dAdapter.Update(dsCarInventory.Tables["Inventory"]);

}

В этом случае вы находите строку, которую нужно удалить (снова с помощью метода Select()), а затем устанавливаете для свойства RowState значение DataRowState.Deleted с помощью вызова Delete().