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
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение
Rocky
  опции профиля:
сообщение 13.1.2011, 16:58
Сообщение #2


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

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

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




Репутация:   7  


С фильтром вроде как разобрался... нужно так писать
m_pModelBook->setFilter(QString("BOOKS.SeriaID = %1").arg(sSeriaID));

так все работает как и задумано... Однако все равно непонятно что это за displayColumn - 3-й параметр конструктора... Я пробовал и так писать
m_pModelBook->setRelation(1, QSqlRelation("SERIAS", "SeriaID", "SeriaName"));

и так
m_pModelBook->setRelation(1, QSqlRelation("SERIAS", "SeriaID", "SeriaID"));

И результаты ничем не отличаются...
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение
Litkevich Yuriy
  опции профиля:
сообщение 16.1.2002, 19:19
Сообщение #3


разработчик РЭА
*******

Группа: Сомодератор
Сообщений: 9669
Регистрация: 9.1.2008
Из: Тюмень
Пользователь №: 64

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




Репутация:   94  


displayColumn - отображаемая колонка, та что подставляется в замен.
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение
ViGOur
  опции профиля:
сообщение 15.1.2011, 15:20
Сообщение #4


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

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

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




Репутация:   40  


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

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


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




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