
Arrow20 марта 2017 г. 0:04
Добавление новой записи в базу данных
Есть база данных с таблицей:
#define TABLE "main" #define TABLE_REG_NUMBER "Reg_number" #define TABLE_SHIFR "Shifr" #define TABLE_NAME "Name"Существуют поля ввода QLineEdit данные в которые подставляются через QDataWidgetMapper:
model = new QSqlTableModel(this); model->setTable(TABLE); model->setEditStrategy(QSqlTableModel::OnManualSubmit); model->select(); mapper = new QDataWidgetMapper(); mapper->setModel(model); mapper->addMapping(ui->reg_numEdit, 1); mapper->addMapping(ui->shifrEdit, 2); mapper->addMapping(ui->nameEdit, 3); mapper->setSubmitPolicy(QDataWidgetMapper::ManualSubmit); mapper->setCurrentModelIndex(model->index(index.row(),0));Далее сохранение данных происходит так:
mapper->submit(); model->submitAll(); model->select();Проблема в том, что данные редактируются и изменения сохраняются без проблем, но только в уже существующих записях. Создавать же новую запись не выходит. Каким образом можно создать новую запись в базе данных?

Рекомендуем хостинг TIMEWEB
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.Вам это нравится? Поделитесь в социальных сетях!
Комментарии
Только авторизованные пользователи могут публиковать комментарии.
Пожалуйста, авторизуйтесь или зарегистрируйтесь
Пожалуйста, авторизуйтесь или зарегистрируйтесь
Ua
- Unknown akadamn
- 24 января 2025 г. 17:14
Qt - Тест 001. Сигналы и слоты
- Результат:84баллов,
- Очки рейтинга4
Ua
- Unknown akadamn
- 24 января 2025 г. 16:22
Qt - Тест 001. Сигналы и слоты
- Результат:42баллов,
- Очки рейтинга-8
Последние комментарии
ИМ
Django - Урок 017. Кастомизированная страница авторизации на Django Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
Игорь Максимов22 ноября 2024 г. 21:51

Evgenii Legotckoi31 октября 2024 г. 23:37
Читалка fb3-файлов на Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
ИМ
Django - Урок 064. Как написать расширение для Python Markdown Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
Игорь Максимов5 октября 2024 г. 16:51
QML - Урок 016. База данных SQLite и работа с ней в QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
Сейчас обсуждают на форуме
f
Рисование на QGraphicsScene при зажатой кнопке мыши Подскажите, пожалуйста! Как данный класс можно дополнить, чтобы созданные объекты можно было перемещать мышкой по сцене?
firstlunoxod15 февраля 2025 г. 13:46

Дмитрий3 февраля 2025 г. 16:24
не запускается компьютер!!! Не запускается компьютер (точнее работает блок , но сам монитор вообще жесть)В общем я ничего с интернета не скачивала в последнее время. На компе никаких левых пр…
Нужно запретить перемещение только некоторых итемов, остальные перемещать можно. Вопрос решен. Узнать QModelIndex элемента на который мы перетаскиваем другой элемент, можно с помощью функции indexAt(event->position().toPoint()) представления QTreeViev вызываемой в переопр…
OAuth2.0 через VK, получение email Спасибо большое за помощь и простите за то что отнял время своей невнимательностью.
Пробовал добавить запись таким образом:
Строка добавляется, но при попытке сохранения исчезает и данные не записываются.Статью https://evileg.com/post/71/ читал и класс обертка реализован по описанному принципу.
Из этого кода проблема не ясна, поскольку он идентичен тому, что в статье.
В самой базе данных случаем нет ограничений на добавление новых записей?
Ограничений нет. Через утилиту SQLiteStudio все добавляется без проблем.
Тогда хотелось бы увидеть более полный листинг
database.h
database.cpp drawwidget.h drawwidget.cpp database - класс базы данных drawwidget - окно программыЯ правильно понимаю, что для одной таблицы, Вы используете две модели данных?
То есть одна используется для отображения в таблицы, а другая используется для работы в QDataWidgetMapper (вопрос риторический, сконцентрируйтесь на этом утверждении)
Таким образом, по клику по кнопке вы добавляете пустуй строку в модель, которая отвечает за таблицу, но не в модель, которая отвечает за маппер.
То есть в модели данных маппера новой строки не появилось. Думаю, что стоит добавлять новую строку не в modelMain , а просто в model . А потом уже обновлять данные через метод select() для mainModel
Дело в том, что если вы добавили строку в одну модель, то она не появится автоматически в другой модели. И исходя из данного кода, новая строка в маппере не появляется.
Пробовал с одной моделью modelMain - в lineEdit не отображаются данные при переходе с одной строки на другую.
Если пробовать добавлять запись в model, а не modelMain запись по прежнему при попытке сохранения не добавляется.
Да. Ещё, без этого участка кода проверяли?
Если быть точным без всего, что касается QSqlRecord . В статье этот класс вообще не применяется. А то получается, что и строку добавили и запись добавили. И дважды маппер двинули на последнюю запись, но при этом всё в главной модели. Масло масляное получается.
Плюсом идёт ещё, что при сохранении данных делаете mainModel->select() , но не делаете того же самого для model . В результате данные для маппера устаревшие получается, и в случае попыток добавить запись, он может пытаться добавить запись с id, который уже существует, а как результат ничего не происходит.
Убрал код:
При сохранении добавил model->select().
Новая запись создается, mapper переходит на нее и можно вносить данные, но при нажатии на кнопку сохранения запись в базу данных не сохраняется. Никаких ошибок или предупреждений не выдает.
Уже хорошо. Уже прогресс. Но это проблема скорее всего в том, что в mapper мапятся не все поля.
Полагаю, что проблема в поле Path и Pict_path, которые вы объявили как NOT NULL, естественно, что запись не создаётся, поскольку они должны быть ненулевыми, а маппер ими вообще не оперирует. Либо делайте в маппере скрытые поля ввода, из которых будет хоть что-то браться, пускай даже мусор. Либо попробуйте разрешить быть этим полям NULL
Спасибо, все работает. А я об объявлении полей как NOT NULL даже и не вспомнил.
Есть еще один маленький вопрос - как мапперу передать определенную строку (путь получаемый с диалога открытия файла), чтобы он внес ее в БД или это проще сделать без его использования конструкцией типа:
И что удобнее и правильнее - хранить в базе данных само изображение, или путь к нему? И если хранится путь, то при переходе на определенную запись в БД используя путь выполнять вставку изображения в QLabel.
Добавьте в mapper ещё один QLineEdit , который будет отвечать за путь к файлу. Когда диалог возвращает этот путь, то установите путь в данный QLineEdit . Если не хотите, чтобы пользователь мог его редактировать, то установите для QLineEdit режим setReadOnly(true) . Или вообще сделайте его скрытым setHidden(true)
Лучше хранить путь к файлу: Во-первых - это будет быстрее, Во-вторых база данных распухнет очень быстро, если в ней файлы хранить.
Спасибо!