Arrow24 червня 2018 р. 10:10
QComboBox и База данных
Добрый день.
Необходима помощь в работе с QComboBox в связке с базой данных.
Описание:
Есть две таблицы:
1) "extension" с полями: id, library, function, ext.
2) "ext_type" с полями: id, type.
Таблицы связаны по полям ext и type. В первую таблицу в поле ext записывается id из второй таблицы.
В главном окне расположена таблица в которой отображаются данные из таблицы extension, в поле ext подставляется вместо id соответствующий type из таблицы "ext_type".
Код:
mainModel = new QSqlRelationalTableModel(this); mainModel->setTable("extension"); mainModel->setSort(0, Qt::AscendingOrder); ui->mainTableView->setModel(mainModel); // Выбор extension с таблицы ext_type по id mainModel->setRelation(3, QSqlRelation("ext_type", "id", "type")); ui->mainTableView->setItemDelegate(new QSqlRelationalDelegate(ui->mainTableView)); mainModel->select(); ui->mainTableView->setColumnHidden(0, true); for (int i = 0; i < ui->mainTableView->horizontalHeader()->count(); i++) { ui->mainTableView->horizontalHeader()->setSectionResizeMode(i, QHeaderView::Stretch); }Все подставляется хорошо.
Второе окно открывается при редактировании записи в таблице или создании новой. На нем расположены QLineEdit для полей library, function и QComboBox для поля extension.
Нужно чтобы при создании новой записи из QComboBox пользователь мог выбрать значения из поля type таблицы ext_type.
Сделал так (под выбор работает а при редактировании существующей записи в QComboBox появляется не та строка):
ОШИБКА ЗДЕСЬ:
model = new QSqlTableModel(this); mapper = new QDataWidgetMapper(); mapper->setModel(model); mapper->addMapping(ui->Line1, 1); mapper->addMapping(ui->Line2, 2); QSqlQueryModel *select = new QSqlQueryModel(this); select->setQuery("select type from ext_type"); ui->comboBox->setModel(select); mapper->addMapping(ui->comboBox, model->fieldIndex("extension"), "currentIndex"); mapper->setSubmitPolicy(QDataWidgetMapper::ManualSubmit); mapper->toLast();Сохранение так (сохраняет, но из comboBox в таблицу попадает не та запись (см. выше)):
mapper->submit();Помогите решить проблему.
model->submitAll();
model->select();
mapper->toLast();
И почему-то
mainModel->setRelation(3, QSqlRelation("ext_type", "id", "type"));с таблицами выше работает.
А в этом случае нет:
mainModel = new QSqlRelationalTableModel(this);В таблицу на форме вообще не выводятся данные (в сама таблица в базе данных заполнена).
mainModel->setTable("security_question");
mainModel->setSort(0, Qt::AscendingOrder);
ui->mainTableView->setModel(mainModel);
// Здесь
mainModel->setRelation(1, QSqlRelation("question", "id", "type"));
ui->mainTableView->setItemDelegate(new QSqlRelationalDelegate(ui->mainTableView));
mainModel->select();
ui->mainTableView->setColumnHidden(0, true);
for (int i = 0; i < ui->mainTableView->horizontalHeader()->count(); i++) {
ui->mainTableView->horizontalHeader()->setSectionResizeMode(i, QHeaderView::Stretch);
}
Структура таблиц:
1) Таблица security_question: id, SecurityQuestion, Answer.
2) Таблица question: id, type.
Что может быль не так?
И подскажите как возможно организовать в базе данных запись в поле таблицы типа result1 или result2 в зависимости от того, какой QRadioButton пользователь выбрал на форме. А также, чтобы при редактировании данных на форме включался нужный QRadioButton в зависимости от записи?
В этом случае пока ничего не придумал.
Заранее спасибо за ответ и извините за долгое и возможно немного не понятное описание вопроса.
Рекомендуємо хостинг TIMEWEB
Стабільний хостинг, на якому розміщується соціальна мережа EVILEG. Для проектів на Django радимо VDS хостинг.Вам це подобається? Поділіться в соціальних мережах!
sf
- sdfsdfkp fgskpgokspdog
- 14 жовтня 2024 р. 15:09
C++ - Тест 004. Указатели, Массивы и Циклы
- Результат:90бали,
- Рейтинг балів8
МВ
- Максим Васильев
- 02 жовтня 2024 р. 04:14
Qt - Тест 001. Сигналы и слоты
- Результат:68бали,
- Рейтинг балів-1
ЛС
- Лев Семенов
- 30 вересня 2024 р. 11:04
C++ - Тест 001. Первая программа и типы данных
- Результат:53бали,
- Рейтинг балів-4
Останні коментарі
Читалка файлів fb3 на Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
ИМ
Django - Урок 064. Як написати розширення для Python Markdown Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
Игорь Максимов05 жовтня 2024 р. 07:51
QML - Урок 016. База даних SQLite та робота з нею в QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
Qt Linux - Урок 001. Автозапуск програми Qt під Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
АК
Qt WinAPI - Урок 007. Робота з ICMP Ping в Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
Анатолий Кононенко05 лютого 2024 р. 01:50
Тепер обговоріть на форумі
добавить qlineseries в функции Пользователь может получить любые разъяснения по интересующим вопросам, касающимся обработки его персональных данных, обратившись к Оператору с помощью электронной почты https://topdecorpro.ru…
ИМ
Реализация навигации по разделам Спасибо Евгений!
Игорь Максимов03 жовтня 2024 р. 04:05
Indian Food Restaurant In Columbus OH| Layla’s Kitchen Indian Restaurant If you're looking for a truly authentic https://www.laylaskitchenrestaurantohio.com/ , Layla’s Kitchen Indian Restaurant is your go-to destination. Located at 6152 Cleveland Ave, Colu…
КГ
Не запускается программа на Qt: точка входа в процедуру не найдена в библиотеке DLL Написал программу на C++ Qt в Qt Creator, сбилдил Release с помощью MinGW 64-bit, бинарнику напихал dll-ки с помощью windeployqt.exe. При попытке запуска моей сбилженной программы выдаёт три оши…
Кирилл Гусарев27 вересня 2024 р. 09:09
при создании qml проекта Kits есть но недоступны для выбора Поставил Qt Creator 11.0.2. Qt 6.4.3 При создании проекта Qml не могу выбрать Kits, они все недоступны, хотя настроены и при создании обычного Qt Widget приложения их можно выбрать. В чем может …
Насчет этого:
Извините вопрос снят, ошибся. В базе данных на поле SecurityQuestion вместо integer поставил тип text.
Вообще должно работать, но там немного нюансы есть, к сожалению уже и не помню какие.
Подскажите как организовать в базе данных запись в поле таблицы типа result1 или result2 в зависимости от того, какой QRadioButton пользователь выбрал на форме. А также, чтобы при редактировании данных на форме включался нужный QRadioButton в зависимости от записи?
Имя поля таблицы "Group name" меня смущает пробел. в нем. Просто никогда не использовал и не видел пробелы в именах полей БД.
Добрый день!
Спасибо за ответ, но там было найдено решение, там одинаковые именя столбцов были в одном месте.
Большое спасибо всем за помощь!
Из опыта: уменьшить время отладки на больших запросах я формирую строку с запросом которую можно скормить клиенту БД и проверяю запрос там. а потом уже использую в коде.
Для больших запросов очень полезно.
Спасибо. У меня в таблице всего 4 столбца, но на будущее возьму на вооружение :)
Такой вопрос. Никто случайно не писал свой класс для QComboBox для работы сполями бызы данных, а то через мапер выходит много однотипного кода. Хочется сократить.
Сейчас делаю так:
Если код не имеет зависимости на какие-то внешние настройки, то можно просто наследоваться и настроить всё однотипное в конструкторе, если есть какие-то внешние параметры, то добавить публичный метод для настройки.
Не очень понял задачу?
Понял, спасибо. Единственные зависимости - имена таблиц и полей.