Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Несколько вопросов по QSqlTableModel и QTableView 
V
    Опции темы
kefir01
Дата 4.8.2010, 13:04 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 213
Регистрация: 22.6.2007

Репутация: 1
Всего: 2



Доброго времени суток!

Вопросы следующие:
1) Можно ли в QSqlTableModel добавить колонку и наполнить ее данными
2) Можно ли заменить в той же QSqlTableModel данные. Например есть колонка с id, а отобразить надо расшифровку из другой таблицы.
3) Каким образом можно вытаскивать данные по выбранной колонке  в QTreeView

p.s.  smile 

И заранее спасибо.
PM MAIL   Вверх
kefir01
Дата 4.8.2010, 16:26 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 213
Регистрация: 22.6.2007

Репутация: 1
Всего: 2



Вопрос №3 решил сам (хорошо или нет - судите сами):

mainwindow.h
Код

#include <QSqlTableModel>
...

public:
    explicit MainWindow(QWidget *parent = 0);
    ~MainWindow();

    QSqlTableModel *docModel;

...


mainwindow.cpp
Код

...

MainWindow::MainWindow(QWidget *parent) :
    QMainWindow(parent),
    ui(new Ui::MainWindow)
{
docModel = new QSqlTableModel;
}
...

void MainWindow::on_tableView_clicked(QModelIndex index)
{
    int id = docModel->record(index.row()).value("ID").toInt();


    QSqlQuery query;
    query.prepare("SELECT NAME,DESCR FROM DOCUMENTS WHERE ID=?");
    query.addBindValue(id);
    query.exec();
    query.first();
...
}


Остальные в процессе - буду рад помощи.


Это сообщение отредактировал(а) kefir01 - 4.8.2010, 16:26
PM MAIL   Вверх
borisbn
Дата 4.8.2010, 18:25 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 4875
Регистрация: 6.2.2010
Где: Ростов-на-Дону

Репутация: 48
Всего: 135



Посмотри QSqlRelationalTableModel IMHO как раз то, что нужно


--------------------
Женщины отличаются от программистов тем, что у них чары состоят из стрингов
PM MAIL Jabber   Вверх
kefir01
Дата 5.8.2010, 19:30 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 213
Регистрация: 22.6.2007

Репутация: 1
Всего: 2



Угу. Спасибо. Это решает вопрос №2 - буду пробовать
PM MAIL   Вверх
kefir01
Дата 6.8.2010, 17:32 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 213
Регистрация: 22.6.2007

Репутация: 1
Всего: 2



Да. Вопрос №2 тоже снят - остается последний. Необходимо вставить ряд, где будет в зависимости от даты отображаться слово активен/неактивен.
PM MAIL   Вверх
kefir01
Дата 9.8.2010, 22:14 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 213
Регистрация: 22.6.2007

Репутация: 1
Всего: 2



Нашел решение вопроса №1 с помощью наследования от QItemDelegate - в свой класс прописал правила на отрисовывание полей.

Можно считать тему закрытой.

Всем спасибо.
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "С/С++: Кроссплатформенное программирование, QT/Gtk+/wxWidgets"
JackYF
Любитель
  • В заголовке темы в квадратных скобках обозначьте используемую вами библиотеку, например: [QT],[GTK],[wx].
  • Если вопрос актуален только для некоторой версии библиотеки, либо, если вы пользуетесь не самой последней версией, укажите это. Например: [QT4], [GTK2].
  • Все начинающие изучать Qt - не забудьте зайти сюда.
  • Проставьте несколько ключевых слов темы, чтобы её можно было легче найти.
  • В вопросе укажите полную версию версию библиотеки, а также все дополнительные используемые программные пакеты.
  • Не забывайте пользоваться кнопкой "Код".
  • Телепатов на форуме нет! Задавайте чёткий, конкретный и полный вопрос. Указывайте полностью ошибки компилятора и компоновщика.
  • Новое сообщение должно иметь прямое отношение к тематике этого раздела. Флуд, флейм, оффтопик запрещены.
  • Категорически запрещается обсуждение вареза, "кряков", взлома программ и т.д.

Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, JackYF, Любитель.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | С/С++: Кроссплатформенное программирование, Qt/Gtk+/wxWidgets | Следующая тема »


 




[ Время генерации скрипта: 0.0657 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.