Russian Qt Forum
Ноябрь 23, 2024, 20:36
Добро пожаловать,
Гость
. Пожалуйста,
войдите
или
зарегистрируйтесь
.
Вам не пришло
письмо с кодом активации?
1 час
1 день
1 неделя
1 месяц
Навсегда
Войти
Начало
Форум
WIKI (Вики)
FAQ
Помощь
Поиск
Войти
Регистрация
Russian Qt Forum
>
Forum
>
Qt
>
Базы данных
>
QSqlRelationalTableModel и NULL
Страниц: [
1
]
Вниз
« предыдущая тема
следующая тема »
Печать
Автор
Тема: QSqlRelationalTableModel и NULL (Прочитано 6651 раз)
Пантер
Administrator
Джедай : наставник для всех
Offline
Сообщений: 5876
Жаждущий знаний
QSqlRelationalTableModel и NULL
«
:
Июль 10, 2008, 12:57 »
Пытаюсь разобраться с QSqlRelationalTableModel и попал в тупик. В общем имеется 2 таблицы
1. FIRST_TABLE:
ID - integer
name - varchar
2. SECOND_TABLE
ID - integer
pole1 - integer (->FIRST_TABLE)
Ставлю релейшн:
model->setRelation(1, QSqlRelation("FIRST_TABLE", "id", "name"));
Так вот если в pole1 хотя бы в одной записи нет значения (т.е. NULL), то данных никаких не показывает. Как нужно правильно делать?
Записан
1. Qt - Qt Development Frameworks; QT - QuickTime
2. Не используйте в исходниках символы кириллицы!!!
3. Пользуйтесь тегом code при оформлении сообщений.
developer
Гость
Re: QSqlRelationalTableModel и NULL
«
Ответ #1 :
Июль 14, 2008, 14:39 »
По моему в доке написано, что для вашего же блага, ми не будем отображать те строки у которых внешние ключи равны NULL. Столкнувшись с этой проблемой, я просто вставлял в нужние поля(в данном случае ети поля - внешные ключи) данные, перехватывая сигнал beforeInserted(...). Это не решыло всех моих проблем, но все таки помогло.
Записан
Mikhail
Программист
Offline
Сообщений: 587
Re: QSqlRelationalTableModel и NULL
«
Ответ #2 :
Июль 14, 2008, 15:51 »
Цитата: panter_dsd от Июль 10, 2008, 12:57
Пытаюсь разобраться с QSqlRelationalTableModel и попал в тупик. В общем имеется 2 таблицы
1. FIRST_TABLE:
ID - integer
name - varchar
2. SECOND_TABLE
ID - integer
pole1 - integer (->FIRST_TABLE)
Ставлю релейшн:
model->setRelation(1, QSqlRelation("FIRST_TABLE", "id", "name"));
Так вот если в pole1 хотя бы в одной записи нет значения (т.е. NULL), то данных никаких не показывает. Как нужно правильно делать?
При создании второй таблицы для pole1 укажи
NOT NULL
например:
CREATE TABLE SECOND_TABLE (
ID int(11) NOT NULL AUTO_INCREMENT PRIMARY KEY,
pole1 int(11) NOT NULL ) ;
Записан
Пантер
Administrator
Джедай : наставник для всех
Offline
Сообщений: 5876
Жаждущий знаний
Re: QSqlRelationalTableModel и NULL
«
Ответ #3 :
Июль 14, 2008, 17:11 »
Цитата: Mikhail от Июль 14, 2008, 15:51
При создании второй таблицы для pole1 укажи
NOT NULL
например:
CREATE TABLE SECOND_TABLE (
ID int(11) NOT NULL AUTO_INCREMENT PRIMARY KEY,
pole1 int(11) NOT NULL ) ;
А как быть, если pole1 не всегда имеет значение?
Записан
1. Qt - Qt Development Frameworks; QT - QuickTime
2. Не используйте в исходниках символы кириллицы!!!
3. Пользуйтесь тегом code при оформлении сообщений.
Mikhail
Программист
Offline
Сообщений: 587
Re: QSqlRelationalTableModel и NULL
«
Ответ #4 :
Июль 14, 2008, 20:28 »
Цитата: panter_dsd от Июль 14, 2008, 17:11
Цитата: Mikhail от Июль 14, 2008, 15:51
При создании второй таблицы для pole1 укажи
NOT NULL
например:
CREATE TABLE SECOND_TABLE (
ID int(11) NOT NULL AUTO_INCREMENT PRIMARY KEY,
pole1 int(11) NOT NULL ) ;
А как быть, если pole1 не всегда имеет значение?
Ну, наверно это вопрос к построению архитектуры базы данных.
Значит не продумано.
Есть такая профессия - системный архитектор баз данных.
Записан
Пантер
Administrator
Джедай : наставник для всех
Offline
Сообщений: 5876
Жаждущий знаний
Re: QSqlRelationalTableModel и NULL
«
Ответ #5 :
Июль 15, 2008, 07:09 »
Ладно, обрисую ситуацию. Есть таблица доходов, где такие поля:
ID номер по порядку
NUMBER номер человека
SUMMA сумма дохода
OSNOVANIE основание, т.е. откуда взяли сведения о доходах.
Релейшн создается по полю OSNOVANIE, но проблема в том, что основания может не быть в 50% случаев. Что тут можно изменить?
Записан
1. Qt - Qt Development Frameworks; QT - QuickTime
2. Не используйте в исходниках символы кириллицы!!!
3. Пользуйтесь тегом code при оформлении сообщений.
ритт
Гость
Re: QSqlRelationalTableModel и NULL
«
Ответ #6 :
Июль 15, 2008, 07:55 »
OSNOVANIE INT NOT NULL DEFAULT 0
Записан
Пантер
Administrator
Джедай : наставник для всех
Offline
Сообщений: 5876
Жаждущий знаний
Re: QSqlRelationalTableModel и NULL
«
Ответ #7 :
Июль 15, 2008, 08:48 »
Птица не дает так сделать, ругается на внешний ключ. В общем или NULL или нормальное значение, но никак не 0.
Записан
1. Qt - Qt Development Frameworks; QT - QuickTime
2. Не используйте в исходниках символы кириллицы!!!
3. Пользуйтесь тегом code при оформлении сообщений.
Tonal
Гость
Re: QSqlRelationalTableModel и NULL
«
Ответ #8 :
Июль 15, 2008, 08:54 »
А в табличку оснований включить основание с ID = 0 и текстам "Без основания".
«
Последнее редактирование: Июль 15, 2008, 08:56 от Tonal
»
Записан
Tonal
Гость
Re: QSqlRelationalTableModel и NULL
«
Ответ #9 :
Июль 15, 2008, 08:56 »
Или наследоваться от QSqlRelationalTableModel и переписать selectStatement чтобы он не выкидывал эти записи.
Записан
Страниц: [
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 сферы
=> Говорилка
=> Юмор
=> Объявления
Загружается...