Russian Qt Forum
Ноябрь 23, 2024, 10:41
Добро пожаловать,
Гость
. Пожалуйста,
войдите
или
зарегистрируйтесь
.
Вам не пришло
письмо с кодом активации?
1 час
1 день
1 неделя
1 месяц
Навсегда
Войти
Начало
Форум
WIKI (Вики)
FAQ
Помощь
Поиск
Войти
Регистрация
Russian Qt Forum
>
Forum
>
Qt
>
Базы данных
>
qt + PostgreSQL. Транзакции
Страниц: [
1
]
Вниз
« предыдущая тема
следующая тема »
Печать
Автор
Тема: qt + PostgreSQL. Транзакции (Прочитано 5515 раз)
vorotislav
Гость
qt + PostgreSQL. Транзакции
«
:
Июнь 23, 2014, 12:46 »
Доброго времени суток. Начал работать с БД PostgreSQL через транзакции. Все замечательно работает - и добавляет записи, и редактирует и удаляет. Но при закрытии программы вылезают в окошке "Вывод приложения" следующие записи:
РџР Р•Р”РЈРџР Р•Р–Р”Р•РќР˜Р•: транзакция уже выполняется
РџР Р•Р”РЈРџР Р•Р–Р”Р•РќР˜Р•: нет незавершённой транзакции
Перевел на русский через Notepad++:
ПРЕДУПРЕЖДЕНИЕ: транзакция уже выполняется
ПРЕДУПРЕЖДЕНИЕ: нет незавершённой транзакции
И не пойму в чем дело. Повесил на каждое открытие\закрытие qDebug() :
if (QSqlDatabase::database().transaction())
qDebug() << "tr addSchemaPoint start";
...
if (QSqlDatabase::database().commit())
qDebug() << "tr addSchemaPoint commit";
При выполнении приложения на каждый старт есть свой коммит, а сообщения все равно остаются. И даже не могу понять какая из транзакций выполняется. Не подскажете как быть? Может как то можно отловить эту выполняющуюся транзакцию. И второе сообщение немного не понятно. Если нет незавершенных транзакций - то зачем предупреждение делать?
Заранее благодарен!
Записан
Old
Джедай : наставник для всех
Offline
Сообщений: 4350
Re: qt + PostgreSQL. Транзакции
«
Ответ #1 :
Июнь 23, 2014, 12:53 »
У postgresql нет вложенных транзакций.
Если вы сделали один раз begin(), то транзакция запустилась, повторный вызов begin() ничего не делает, кроме выдачи предупреждения.
Тоже и с commit: первый закрывает начатую транзакцию, второй выдает предупреждение, что активных транзакций нет.
Записан
vorotislav
Гость
Re: qt + PostgreSQL. Транзакции
«
Ответ #2 :
Июнь 23, 2014, 14:24 »
Old, спасибо большое! Наверняка проблема в этом, у меня есть такие ситуации! Сегодня уберу:)
Записан
Страниц: [
1
]
Вверх
Печать
« предыдущая тема
следующая тема »
Перейти в:
Пожалуйста, выберите назначение:
-----------------------------
Qt
-----------------------------
=> Вопросы новичков
=> Уроки и статьи
=> Установка, сборка, отладка, тестирование
=> Общие вопросы
=> Пользовательский интерфейс (GUI)
=> Qt Quick
=> Model-View (MV)
=> Базы данных
=> Работа с сетью
=> Многопоточное программирование, процессы
=> Мультимедиа
=> 2D и 3D графика
=> OpenGL
=> Печать
=> Интернационализация, локализация
=> QSS
=> XML
=> Qt Script, QtWebKit
=> ActiveX
=> Qt Embedded
=> Дополнительные компоненты
=> Кладовая готовых решений
=> Вклад сообщества в Qt
=> Qt-инструментарий
-----------------------------
Программирование
-----------------------------
=> Общий
=> С/C++
=> Python
=> Алгоритмы
=> Базы данных
=> Разработка игр
-----------------------------
Компиляторы и платформы
-----------------------------
=> Linux
=> Windows
=> Mac OS X
=> Компиляторы
===> Visual C++
-----------------------------
Разное
-----------------------------
=> Новости
===> Новости Qt сообщества
===> Новости IT сферы
=> Говорилка
=> Юмор
=> Объявления
Загружается...