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 хостинг.Вам це подобається? Поділіться в соціальних мережах!
AD
- Akiv Doros
- 11 листопада 2024 р. 14:58
C++ - Тест 004. Указатели, Массивы и Циклы
- Результат:50бали,
- Рейтинг балів-4
m
- molni99
- 26 жовтня 2024 р. 01:37
C++ - Тест 004. Указатели, Массивы и Циклы
- Результат:80бали,
- Рейтинг балів4
m
- molni99
- 26 жовтня 2024 р. 01:29
C++ - Тест 004. Указатели, Массивы и Циклы
- Результат:20бали,
- Рейтинг балів-10
Останні коментарі
ИМ
Django - Підручник 017. Налаштуйте сторінку входу до Django Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
Игорь Максимов22 листопада 2024 р. 11:51
Evgenii Legotckoi31 жовтня 2024 р. 14:37
Читалка файлів 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 аналогично. Могу предположить, что из-за более новой верси…
Тепер обговоріть на форумі
Evgenii Legotckoi24 червня 2024 р. 15:11
t
google domain [url=https://google.com/]domain[/url] domain [http://www.example.com link title]
tonypeachey115 листопада 2024 р. 06:04
NSProject04 червня 2022 р. 03:49
IscanderChe31 жовтня 2024 р. 15:43
Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…
Насчет этого:
Извините вопрос снят, ошибся. В базе данных на поле SecurityQuestion вместо integer поставил тип text.
Вообще должно работать, но там немного нюансы есть, к сожалению уже и не помню какие.
Подскажите как организовать в базе данных запись в поле таблицы типа result1 или result2 в зависимости от того, какой QRadioButton пользователь выбрал на форме. А также, чтобы при редактировании данных на форме включался нужный QRadioButton в зависимости от записи?
Имя поля таблицы "Group name" меня смущает пробел. в нем. Просто никогда не использовал и не видел пробелы в именах полей БД.
Добрый день!
Спасибо за ответ, но там было найдено решение, там одинаковые именя столбцов были в одном месте.
Большое спасибо всем за помощь!
Из опыта: уменьшить время отладки на больших запросах я формирую строку с запросом которую можно скормить клиенту БД и проверяю запрос там. а потом уже использую в коде.
Для больших запросов очень полезно.
Спасибо. У меня в таблице всего 4 столбца, но на будущее возьму на вооружение :)
Такой вопрос. Никто случайно не писал свой класс для QComboBox для работы сполями бызы данных, а то через мапер выходит много однотипного кода. Хочется сократить.
Сейчас делаю так:
Если код не имеет зависимости на какие-то внешние настройки, то можно просто наследоваться и настроить всё однотипное в конструкторе, если есть какие-то внешние параметры, то добавить публичный метод для настройки.
Не очень понял задачу?
Понял, спасибо. Единственные зависимости - имена таблиц и полей.