Добавил:
Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
БД / SUBD.doc
Скачиваний:
65
Добавлен:
30.01.2019
Размер:
407.04 Кб
Скачать

23) Перемещение записей из одной таблицы в другую (например, в Корзину).

В компьютерном салоне клиент выбирает компонентов компьютера, и тем самым определяет конфигурацию своего компьютера. Обычно выбранные товары следует переместить в таблицу-корзину.

Для организации этой работы добавьте в базу данных новую таблицу Korzina. Эта таблица должна содержать основных характеристик товаров, поэтому для него определите следующих полей: TovarID, TovarName, Price и Kol. Чтобы отображать данных таблицы Korzina на форме, разместите элемент управления dataGridView2. Также разместите два текстовых поля для ввода количества товаров и для отображения стоимости набранных товаров (Рис. 1.30).

Рис. 1.30. Добавление товаров в Корзину

Для работы с таблицей Korzina объявите глобальных переменных.

public partial class Form1 : Form

{

string strKorzina;

SqlCommand cmdKorzina;

SqlDataAdapter adapKorzina;

DataTable Korzina;

BindingSource bsKorzina;

. . . . . . . . . . . . . . .

В обработчике события Form_Load добавьте код для вывода таблицы Korzina в элементе управления dataGridView2.

private void Form1_Load(...)

{

. . . . . . . . . . . . . . . . . . .

strKorzina = "SELECT * FROM Korzina ";

cmdKorzina = new SqlCommand(strKorzina, conn);

// Копирование данных в локальную таблицу

adapKorzina = new SqlDataAdapter(cmdKorzina);

Korzina = new DataTable();

adapKorzina.Fill(Korzina);

// Привязка данных на DataGridView

bsKorzina = new BindingSource();

bsKorzina.DataSource = Korzina;

dataGridView2.DataSource = bsKorzina;

}

Для реализации перемещения товара из таблицы Tovars в таблицу Korzina на форме разместите кнопку Выбор.

В обработчике события кнопки Выбор вы должны формировать и выполнить SQL-команду INSERT для таблицы Korzina. Ниже приведен код этого обработчика события.

private void button1_Click(...)

{

DataGridViewRow curRow = dataGridView1.CurrentRow;

string TovarID = curRow.Cells["TovarID"].Value.ToString() + ", ";

string TovarName =

"'" +curRow.Cells["TovarName"].Value.ToString() + "', ";

string Price = curRow.Cells["Price"].Value.ToString() + ", ";

string Kol = textBox1.Text;

string insertStr = "INSERT INTO Korzina " +

"(TovarID, TovarName, Price, Kol) " +

"VALUES (" + TovarID + TovarName + Price + Kol + ")";

SqlCommand insertCmd = new SqlCommand(insertStr, conn);

insertCmd.ExecuteNonQuery();

// Вывод данных обновленной таблицы

Korzina.Clear();

adapKorzina.Fill(Korzina);

textBox2.Text = SumTovars().ToString();

}

24) Использование транзакций. Команды для формирования тела транзакции, для подтверждения и отказа от транзакции

Для реализации группового выполнения SQL-запросов предназначены транзакции. SQL-запросы можно сгруппировать в транзакцию, а затем зафиксировать результат или откатить эту транзакцию как одно целое. Например, команд INSERT и UPDATE в примере компьютерного салона можно поместить в транзакцию, а затем подтвердить или откатить эту транзакцию как одно целое, в зависимости от того, выполнились ли успешно оба SQL-запроса.

Для начала транзакции используется оператор BEGIN TRANSACTION (сокращенно BEGIN TRANS), а далее следуют составляющие транзакцию SQL-команды. Чтобы зафиксировать транзакцию, исполняется запрос COMMIT TRANSACTION (сокращенно COMMIT), а для отката транзакции выполняется запрос ROLBACK TRANSACTION (сокращенно ROLLBACK).

измените код кнопки выбора товаров в Корзину.

private void button1_Click(...)

{

DataGridViewRow curRow = dataGridView1.CurrentRow;

string TovarID = curRow.Cells["TovarID"].Value.ToString();

string TovarName = "'" + (string)curRow.Cells["TovarName"].Value

+ "', ";

string Price = curRow.Cells["Price"].Value.ToString() + ", ";

string Kol = textBox1.Text;

string insertStr = "INSERT INTO Korzina " +

"(TovarID, TovarName, Price, Kol) " +

"VALUES (" + TovarID + ", " + TovarName + Price + Kol + ")";

SqlCommand insertCmd = new SqlCommand(insertStr, conn);

// Объекты для обновления таблицы Tovari

int curKol = (int)curRow.Cells["Kol"].Value;

curKol = curKol - Convert.ToInt32(Kol);

string updateStr = "UPDATE Tovars SET Kol = " + curKol +

" WHERE TovarID =" + TovarID;

SqlCommand updateCmd = new SqlCommand(updateStr, conn);

// Создание объектов для транзакции

SqlCommand transCmd = new SqlCommand("BEGIN TRANSACTION", conn);

transCmd.ExecuteNonQuery();

insertCmd.ExecuteNonQuery();

updateCmd.ExecuteNonQuery();

transCmd.CommandText = "COMMIT";

transCmd.ExecuteNonQuery();

. . . . . . . . . . . . . . . .

}