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 в зависимости от записи?
В этом случае пока ничего не придумал.
Заранее спасибо за ответ и извините за долгое и возможно немного не понятное описание вопроса.
3
252
Do you like it? Share on social networks!
- Last comments
- AKApril 1, 2025, 11:41 a.m.Добрый день. В данный момент работаю над проектом, где необходимо выводить звук из программы в определенное аудиоустройство (колонки, наушники, виртуальный кабель и т.д). Пишу на Qt5.12.12 поско…
- VPMarch 9, 2025, 4:14 p.m.Здравствуйте! Я устанавливал Qt6 из исходников а также Qt Creator по отдельности. Все компоненты, связанные с разработкой для Android, установлены. Кроме одного... Когда пытаюсь скомпилиров…
- Now discuss on the forum
- DTApril 14, 2025, 3:38 p.m.Всем привет! На Qt 6.8 MinGW пытаюсь сделать управление подключением WiFi из программы. Пока делаю поддержку Windows, но так же хочу в дальнейшем внедрить и поддержку Linux/MacOS. Для…
- fFeb. 15, 2025, 1:46 p.m.Подскажите, пожалуйста! Как данный класс можно дополнить, чтобы созданные объекты можно было перемещать мышкой по сцене?
- Не запускается компьютер (точнее работает блок , но сам монитор вообще жесть)В общем я ничего с интернета не скачивала в последнее время. На компе никаких левых пр…
- Вопрос решен. Узнать QModelIndex элемента на который мы перетаскиваем другой элемент, можно с помощью функции indexAt(event->position().toPoint()) представления QTreeViev вызываемой в переопр…
Насчет этого:
Извините вопрос снят, ошибся. В базе данных на поле SecurityQuestion вместо integer поставил тип text.
Вообще должно работать, но там немного нюансы есть, к сожалению уже и не помню какие.
Подскажите как организовать в базе данных запись в поле таблицы типа result1 или result2 в зависимости от того, какой QRadioButton пользователь выбрал на форме. А также, чтобы при редактировании данных на форме включался нужный QRadioButton в зависимости от записи?
Имя поля таблицы "Group name" меня смущает пробел. в нем. Просто никогда не использовал и не видел пробелы в именах полей БД.
Добрый день!
Спасибо за ответ, но там было найдено решение, там одинаковые именя столбцов были в одном месте.
Большое спасибо всем за помощь!
Из опыта: уменьшить время отладки на больших запросах я формирую строку с запросом которую можно скормить клиенту БД и проверяю запрос там. а потом уже использую в коде.
Для больших запросов очень полезно.
Спасибо. У меня в таблице всего 4 столбца, но на будущее возьму на вооружение :)
Такой вопрос. Никто случайно не писал свой класс для QComboBox для работы сполями бызы данных, а то через мапер выходит много однотипного кода. Хочется сократить.
Сейчас делаю так:
Если код не имеет зависимости на какие-то внешние настройки, то можно просто наследоваться и настроить всё однотипное в конструкторе, если есть какие-то внешние параметры, то добавить публичный метод для настройки.
Не очень понял задачу?
Понял, спасибо. Единственные зависимости - имена таблиц и полей.