Форум программистов, компьютерный форум, киберфорум
MySQL
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.95/22: Рейтинг темы: голосов - 22, средняя оценка - 4.95
 Аватар для iPIPka
39 / 39 / 5
Регистрация: 06.02.2011
Сообщений: 123

Откат транзакции

05.04.2011, 18:59. Показов 4245. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Расскажу суть проблемы на примере.
1. Создаю таблицу
SQL
1
2
3
4
5
CREATE TABLE tab (
  id INT,
  name CHAR(32) NOT NULL,
  PRIMARY KEY(id)
)ENGINE=INNODB
2. Создаю процедуру, которая содержит транзакцию.
SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
DELIMITER $$
CREATE PROCEDURE Procc(OUT aaa INT)
BEGIN
  DECLARE a1, a2, a3, a4 INT DEFAULT 0;
  START TRANSACTION;
    INSERT INTO tab (id, name) VALUES (1, 'qwe');
    SET a1=ROW_COUNT();
    INSERT INTO tab (id, name) VALUES (2, 'qwe');
    SET a2=ROW_COUNT();
    INSERT INTO tab (id, name) VALUES (3, NULL);
    SET a3=ROW_COUNT();
    INSERT INTO tab (id, name) VALUES (4, 'qwe');
    SET a4=ROW_COUNT();
    SET aaa=45;
    IF (a1=1 AND a2=1 AND a3=1 AND a4=1) 
      THEN COMMIT; 
    ELSE ROLLBACK; 
    END IF;
  END$$
DELIMITER ;
По моей, видимо неправильной, логике третий INSERT выполняется в ошибкой, значит в а3 запишется значение -1 и произойдет откат транзакции.
Но после ошибки (в 10 строке) процедура дальше не выполняется, соответственно отката не происходит. Ну, а если вместо INSERT INTO использовать INSERT IGNORE INTO, то в переменную а3 записывается 1, что в данном случает не подходит.

Собственно, прошу подсказать, как можно процедуру подправить, чтобы все работало.
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
05.04.2011, 18:59
Ответы с готовыми решениями:

Транзакции
Есть две таблицы , в первой содержаться имена(Ваня, Андрей, Иван) , во второй их лицевой счет, как сделать так чтобы при изменении лицевого...

Транзакции
есть таблица, из двух полей (id - уникальный ключ, идентификатор пользователя и summ - количество денег) Подскажите как правильно...

транзакции
нашел пример в интернете BEGIN TRANSACTION INSERT СОТРУДНИКИ (TAB) VALUES (5) INSERT ОТРАБОТАНО (TAB) VALUES (5) IF @@ERROR = 0 ...

2
4217 / 3059 / 583
Регистрация: 21.01.2011
Сообщений: 13,203
06.04.2011, 09:45
Лучший ответ Сообщение было отмечено iPIPka как решение

Решение

Почитай про обработку исключений - mysql exception handling

Например, здесь
http://dev.mysql.com/tech-reso... -apps.html
1
 Аватар для iPIPka
39 / 39 / 5
Регистрация: 06.02.2011
Сообщений: 123
06.04.2011, 23:25  [ТС]
Цитата Сообщение от Grossmeister Посмотреть сообщение
Почитай про обработку исключений - mysql exception handling
Например, здесь
http://dev.mysql.com/tech-reso... -apps.html
Спасибо большое! Конкретно Ваша ссылка не особо помогла, но направление задали мне верное, и я нашла-таки информацию об обработке исключений в MySQL.

В итоге, процедура получилась вот такой, если, вдруг, кого-то заинтересует.
Oracle 11 SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
DELIMITER $$
DROP PROCEDURE IF EXISTS Procc $$
 
CREATE PROCEDURE Procc()
BEGIN
 DECLARE err INT DEFAULT 0;
 BEGIN
  DECLARE CONTINUE HANDLER FOR SQLEXCEPTION SET err=1;
  START TRANSACTION;
  INSERT INTO tab (id, name) VALUES (1, 'qwe');
  INSERT INTO tab (id, name) VALUES (2, 'qwe');
  INSERT INTO tab (id, name) VALUES (3, NULL);
  INSERT INTO tab (id, name) VALUES (4, 'qwe');
 END;
 IF (err=0) 
  THEN COMMIT; 
  ELSE ROLLBACK; 
 END IF;
 END$$
DELIMITER ;
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
06.04.2011, 23:25
Помогаю со студенческими работами здесь

Изоляция в транзакции
Добрый день. Вопрос простой. Есть некая последовательность: 1. Запрос на получение количество строк в одной из таблиц 2. Insert в...

MyISAM транзакции
Я намерено вызываю ошибку при регистрации, но запись пользователя все равно появляется в БД, что я делаю не так? По логике добавление...

Транзакции и блокировки
Привет. Есть две транзакции: T1 (запускается первой) всегда REPEATABLE READ 1) Обновление table_1 2) Запуск T2 2) Обновление...

Возможности транзакции
Всем привет, возможно ли сделать следущее с транзакциями, если нет, то подскажите как правильно сделать: В одном фрейме есть три...

SELECT + Транзакции
Доброго времени суток! И так, в процессе разработки появилась задача записи информации в несколько таблиц БД с учетом нескольких проверок...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Программа принимает математическое выражение в виде строки и выдаёт его производную в виде строки и вычисляет значение производной при заданном х Логарифм записывается как: (x-2)log(x^2+2) -. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru