Russian Qt Forum
Ноябрь 23, 2024, 23:50
Добро пожаловать,
Гость
. Пожалуйста,
войдите
или
зарегистрируйтесь
.
Вам не пришло
письмо с кодом активации?
1 час
1 день
1 неделя
1 месяц
Навсегда
Войти
Начало
Форум
WIKI (Вики)
FAQ
Помощь
Поиск
Войти
Регистрация
Russian Qt Forum
>
Forum
>
Qt
>
Базы данных
>
QSqlRelationalTableModel
Страниц: [
1
]
Вниз
« предыдущая тема
следующая тема »
Печать
Автор
Тема: QSqlRelationalTableModel (Прочитано 4003 раз)
aliks-os
Гость
QSqlRelationalTableModel
«
:
Ноябрь 27, 2009, 12:26 »
Есть вот такая простая вещь
QSqlRelationalTableModel *model = new QSqlRelationalTableModel;
model->setTable("objects");
model->setRelation(1, QSqlRelation("object_type","id","name"));
Соответственно в первом столбце имеется поле "name" из связанной таблицы.
Когда я делаю вот такой запрос, то я получаю "name".
QSqlRecord record = model->record(ui->tableMain->currentIndex().row());
Подскажите пожалуйста, как мне получать не значение которые получается в результате связывание, а индентификатор по которому производится связывание таблиц
«
Последнее редактирование: Ноябрь 27, 2009, 12:37 от aliks-os
»
Записан
cya-st
Гость
Re: QSqlRelationalTableModel
«
Ответ #1 :
Ноябрь 27, 2009, 12:47 »
Вообще то я не очень понял вопрос.
Код:
QSqlRecord rec = table1.record();
table1.value(rec.indexOf("id")).toString();
Записан
aliks-os
Гость
Re: QSqlRelationalTableModel
«
Ответ #2 :
Ноябрь 27, 2009, 12:54 »
Видно коряво описал проблему, постараюсь более подробно
Есть 2 таблицы
таб1 objects
id
object_type_id
таб2 object_type
id
name
Первая таблица основная, к первой таблице по первому полю (object_type_id) присоединяю вторую таблицу.
Проблема, когда я пишу
QSqlRecord record = model->record(ui->tableMain->currentIndex().row());
record.value(1).toString();
то получаю значение name из второй таблицы.
а мне нужно получить значение object_type_id из первой таблицы
Записан
cya-st
Гость
Re: QSqlRelationalTableModel
«
Ответ #3 :
Ноябрь 27, 2009, 16:23 »
Объеденить через
QSqlQuery
подойдет?
Записан
cya-st
Гость
Re: QSqlRelationalTableModel
«
Ответ #4 :
Ноябрь 27, 2009, 16:30 »
Цитата: cya-st от Ноябрь 27, 2009, 16:23
Объеденить через
QSqlQuery
подойдет?
Тоесть простой SQL - запрос.
Если тебе нужно выводить две таблицы (главная подчиненная), то надо правильно соединить таблицы и выводить поля с соответствующей таблицы.
Записан
aliks-os
Гость
Re: QSqlRelationalTableModel
«
Ответ #5 :
Ноябрь 30, 2009, 09:40 »
Объединить через QSqlQuery конечно можно, но тогда комбо-боксы через связанные ключи выскакивать не будут, так что это не подходит однозначно
Записан
cya-st
Гость
Re: QSqlRelationalTableModel
«
Ответ #6 :
Ноябрь 30, 2009, 11:52 »
Покажи код, как ты связываеш таблицы.
Записан
Страниц: [
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 сферы
=> Говорилка
=> Юмор
=> Объявления
Загружается...