Russian Qt Forum
Ноябрь 24, 2024, 12:45
Добро пожаловать,
Гость
. Пожалуйста,
войдите
или
зарегистрируйтесь
.
Вам не пришло
письмо с кодом активации?
1 час
1 день
1 неделя
1 месяц
Навсегда
Войти
Начало
Форум
WIKI (Вики)
FAQ
Помощь
Поиск
Войти
Регистрация
Russian Qt Forum
>
Forum
>
Qt
>
Базы данных
>
Как удалить строку из модели без внесения изменений в БД?
Страниц: [
1
]
Вниз
« предыдущая тема
следующая тема »
Печать
Автор
Тема: Как удалить строку из модели без внесения изменений в БД? (Прочитано 4070 раз)
browncoat
Гость
Как удалить строку из модели без внесения изменений в БД?
«
:
Ноябрь 11, 2010, 12:36 »
Использую QSqlRelationalTableModel. Строки добавляются в модель (insertRow) и без последующего вызова submitAll(), а для удаления строки (removeRow) необходимо вызывать submitAll(). Есть ли способ удалять строки из модели без сабмита? Это нужно для того, чтобы пользователь мог удалять строки из таблиц, но изменения в БД вносились только после нажатия кнопки "Сохранить".
«
Последнее редактирование: Ноябрь 13, 2010, 13:22 от browncoat
»
Записан
break
Гипер активный житель
Offline
Сообщений: 846
Re: Как удалить строку из модели без внесения изменений в БД?
«
Ответ #1 :
Ноябрь 11, 2010, 12:45 »
чудеса какие-то... стоит onManualSubmit в QSqlTableModel::EditStrategy ?
Записан
browncoat
Гость
Re: Как удалить строку из модели без внесения изменений в БД?
«
Ответ #2 :
Ноябрь 11, 2010, 13:07 »
Да, onManualSubmit установлено.
Я ошибся, данные из модели удаляются. Это какая-то проблема во взаимодействии модели с маппером.
upd1
Странно. Добавленные в модель строки (которые еще не сохранены) нормально удаляются. А те, которые уже были в базе, похоже не удаляются, а только помечаются для удаления, а само удаление происходит после вызова submitAll().
upd2
Для демонстрации того, о чем я говорю написал небольшую программку (исходники в приложении). Создаю БД, добавляю в нее 2 строки, подключаю модель (установлено onManualSubmit). Добавляю строку в модель, все нормально rowCount модели увеличивается. Затем удаляю последнюю строку, все ок. А вот предыдущие строки (те, которые уже были в БД до подключения модели) не удаляются! Удаление происходит только после вызова submitAll(). Почему так?
«
Последнее редактирование: Ноябрь 12, 2010, 10:41 от browncoat
»
Записан
nata267
Гость
Re: Как удалить строку из модели без внесения изменений в БД?
«
Ответ #3 :
Декабрь 17, 2010, 11:22 »
У меня та же самая проблемма, они отмечаются !
Записан
break
Гипер активный житель
Offline
Сообщений: 846
Re: Как удалить строку из модели без внесения изменений в БД?
«
Ответ #4 :
Декабрь 17, 2010, 11:40 »
Все работает так как и должно - строки которые не были занесены в БД - удаляются сразу, те которые были в БД помечаются и будут удалены после вызова submitAll если установлено onManualSubmit. цехелла виновата.
Записан
nata267
Гость
Re: Как удалить строку из модели без внесения изменений в БД?
«
Ответ #5 :
Декабрь 17, 2010, 15:15 »
их можно спрятать во view
Записан
Страниц: [
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 сферы
=> Говорилка
=> Юмор
=> Объявления
Загружается...