crossplatform.ru

Здравствуйте, гость ( Вход | Регистрация )

> Непонятный конструктор QSqlRelation, (
Rocky
  опции профиля:
сообщение 13.1.2011, 12:48
Сообщение #1


Старейший участник
****

Группа: Участник
Сообщений: 530
Регистрация: 22.12.2008
Из: Санкт-Петербург
Пользователь №: 463

Спасибо сказали: 22 раз(а)




Репутация:   7  


Всем привет! Вот читаю описание конструктора класса
QSqlRelation::QSqlRelation ( const QString & tableName, const QString & indexColumn, const QString & displayColumn )
Constructs a QSqlRelation object, where tableName is the SQL table name to which a foreign key refers, indexColumn is the foreign key,
and displayColumn is the field that should be presented to the user.

Может кто-нибудь объяснить пожалуйста, что это за displayColumn? Где он, в какой таблице отображается пользователю? Я чето вообще не доганяю. Просто вот у меня есть пример (написал программу-картотеку):
m_pModelBook = new QSqlRelationalTableModel(this);
m_pModelBook->setTable("BOOKS");
m_pModelBook->setRelation(1, QSqlRelation("SERIAS", "SeriaID", "SeriaName"));
m_pModelBook->select();

Поле SeriaID - это PM в таблице SERIAS. Это же поле в колонке 1 в таблице BOOKS. Далее ставлю фильтр на модель книг. Хочу, чтобы в QTableView показывались только книги, у которых определенный SeriaID. Делаю так:
m_pModelBook->setFilter("SeriaID = 10");

SeriaID 10 100% есть в обоих таблицах. Результат - QTableView пустой. А вот если написать
m_pModelBook->setFilter("SeriaName = 'С++'");

, то в QTableView отображаются все книги, которые занесены в таблицу BOOKS, и у которых поле SeriaID указывает на запись таблицы SERIAS, и этому SeriaID соответствует SeriaName "С++".

Проблема в том, что в БД (использую SQLite) всего одна таблица SERIAS. И там может быть несколько записей с одним и тем же именем (например "Общее"), но с разными SeriaID. Поэтому правильно ставить фильтр на SeriaID а не на SeriaName. Что я делаю не так?

Спасибо.

Сообщение отредактировал Rocky - 13.1.2011, 12:49
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение
 
Начать новую тему
Ответов
ViGOur
  опции профиля:
сообщение 15.1.2011, 15:20
Сообщение #2


Мастер
******

Группа: Модератор
Сообщений: 3296
Регистрация: 9.10.2007
Из: Москва
Пользователь №: 4

Спасибо сказали: 231 раз(а)




Репутация:   40  


up
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение

Сообщений в этой теме


Быстрый ответОтветить в данную темуНачать новую тему
Теги
Нет тегов для показа


5 чел. читают эту тему (гостей: 5, скрытых пользователей: 0)
Пользователей: 0




RSS Текстовая версия Сейчас: 3.1.2025, 7:26