AC
18 травня 2023 р. 14:06

Несколько запросов к БД в рамках одной транзакции

QT

Доброго времени суток.
Как правильно выполнить запросы в рамках одной транзакции ?

db->getDatabase().transaction();
QString str_error;
QSqlQuery qry;
//** 1
qry.prepare("INSERT ...");
if (qry.exec())
    str_error = str_error + qry.lastError().text();
//** 2
qry.prepare("INSERT ...");
if (qry.exec())
    str_error = str_error + qry.lastError().text();
//** 3
qry.prepare("INSERT ...");
if (qry.exec())
    str_error = str_error + qry.lastError().text();

if (str_error.isEmpty())
    db->getDatabase().commit();
else
    db->getDatabase().rollback();

... к примеру если во втором запросе ошибка, то в любом случае выполняются 1 и 3.
Никак не могу разобраться.
Буду благодарен в помощи.

3

Вам це подобається? Поділіться в соціальних мережах!

2
PB
  • 18 травня 2023 р. 14:27
  • (відредаговано)
  • Відповідь була позначена як рішення.
db->getDatabase().transaction();
QString str_error;
QSqlQuery qry;
bool success = true;
try {
    qry.prepare("INSERT ...");
    if (!qry.exec()) {
        str_error = str_error + qry.lastError().text();
        success = false;
    }
    qry.prepare("INSERT ...");
    if (!qry.exec()) {
        str_error = str_error + qry.lastError().text();
        success = false;
    }
    qry.prepare("INSERT ...");
    if (!qry.exec()) {
        str_error = str_error + qry.lastError().text();
        success = false;
    }
    if (success)
        db->getDatabase().commit();
    else
        db->getDatabase().rollback();
}
catch (...) {
    db->getDatabase().rollback();
    throw;
}
    AC
    • 18 травня 2023 р. 15:36

    Спасибо.

      Коментарі

      Only authorized users can post comments.
      Please, Log in or Sign up