AC
Мамыр 18, 2023, 2: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, 2: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, 3:36 Т.Қ.

    Спасибо.

      Пікірлер

      Тек рұқсаты бар пайдаланушылар ғана пікір қалдыра алады.
      Кіріңіз немесе Тіркеліңіз