Russian Qt Forum
Сентябрь 30, 2024, 06:30 *
Добро пожаловать, Гость. Пожалуйста, войдите или зарегистрируйтесь.
Вам не пришло письмо с кодом активации?

Войти
 
  Начало   Форум  WIKI (Вики)FAQ Помощь Поиск Войти Регистрация  

Страниц: [1] 2   Вниз
  Печать  
Автор Тема: QSqlTableModel + QTableView - всякие разные вопросы в одном топике  (Прочитано 16547 раз)
PavelVX
Гость
« : Июль 11, 2012, 12:12 »

Задача просто до неприличия, но что-то торможу конкретно.
К примеру есть таблица t1 с полями: key, user, f1, f2, f3.
key - первичный ключ t1
user - ключ к другой таблице, t2: user, u_name, f1, f2.
как мне в QTableView сделать следующий вид, по заголовкам:
key, user, user, f1, f2, f3 не прибегая к вью?
Дело вот в чем. Хочу дать на редактирование след структуру: key, user, user(делегат, на самом деле показывающий u_user), f1, f2, f3
И попутный вопрос: можно ли програмно получить название колонок, как они называются в базе?
« Последнее редактирование: Август 29, 2012, 10:43 от PavelVX » Записан
kibsoft
Хакер
*****
Offline Offline

Сообщений: 625


Просмотр профиля WWW
« Ответ #1 : Июль 11, 2012, 15:40 »

http://doc.qt.nokia.com/4.7-snapshot/qsqlrelationaltablemodel.html#details - вам сюда
Записан

http://kibsoft.ru - Download the Qt Media Encoding Library here

The apps that were written using QtMEL:
http://srecorder.com - Screen recording software
PavelVX
Гость
« Ответ #2 : Июль 12, 2012, 07:07 »

к сожалению, вы не прочитали постановку проблемы Грустный
Если бы мне нужно было только u_name, то я бы даже не писал сюда ... а мне нужен еще и код.
Могу перефразировать задачу: есть таблица в которой хранятся артикул/штрих код товара + цена отгрузки и есть название товара в другой таблице.
Как через QSqlTableModel + QTableView показать и артикул и название товара?
Записан
Whiplash
Гость
« Ответ #3 : Июль 12, 2012, 08:48 »

Всё таки, имхо, все эти SqlTableModel, SqlRelationTableModel - от лукавого. Есть модел QSqlQueryModel - даёшь какой тебе надо запрос и наслаждаешься. Для редактирования данных - отсабклассить её, да и делов.
Записан
Странник
Гость
« Ответ #4 : Июль 12, 2012, 14:36 »

из коробки - никак, нужно писать свою модель. хотя я предпочитаю решать эту задачу иначе, но здесь все зависит от возможностей вашей СУБД. в большинстве случаев довольно удобно создавать на сервере слой абстракции из представлений, с которыми работает пользовательское приложение, в то время как реальные таблицы остаются от него скрыты. изменение данных реализуется с помощью триггеров на представлении. таким образом пользовательское приложение никак не привязано к структуре таблиц, да и потребность в куцом QSqlRelationalTableModel отпадает.
Записан
PavelVX
Гость
« Ответ #5 : Июль 13, 2012, 06:45 »

Спасибо за развернутые ответы. Что-то подобное я предполагал. Пошел по пути создания всяких редактируемых view на серваке.
QSqlQueryModel - у него один офигенный минус, который перекрывает все плюсы: если его делать редактируемым, то при обновлении данных, он дергает весь набор записей заново, а это может быть долго.
PS странник, а не подскажите пару моментов?
1. На серваке вью/таблица, без разницы. Если я добавлю там колонку, то в QTableView, по умолчанию, её покажет. А можно как-то запрограммировать показ только обозначенных мной колонок? Иначе как-то странным представляется процесс добавления функционала.
2. Можно ли как-то програмно у QTableView или её модели узнать реальное название колонки, а не то, что я пропишу в заголовке?
« Последнее редактирование: Июль 13, 2012, 07:21 от PavelVX » Записан
Странник
Гость
« Ответ #6 : Июль 13, 2012, 09:10 »

1. На серваке вью/таблица, без разницы. Если я добавлю там колонку, то в QTableView, по умолчанию, её покажет. А можно как-то запрограммировать показ только обозначенных мной колонок? Иначе как-то странным представляется процесс добавления функционала.
2. Можно ли как-то програмно у QTableView или её модели узнать реальное название колонки, а не то, что я пропишу в заголовке?

1. для программного или пользовательского скрытия/отображения колонок и сохранения/загрузки их текущего состояния:
Цитировать
void QTableView::setColumnHidden ( int column, bool hide )
void QTableView::hideColumn ( int column ) [slot]
void QTableView::showColumn ( int column ) [slot]
QByteArray QHeaderView::saveState () const
bool QHeaderView::restoreState ( const QByteArray & state )

2. реальное название - это то, которое прописано для столбца в вашем представлении на сервере? можно узнать в модели:
Код:
model->record().fieldName(fieldIndex);
где fieldIndex - индекс столбца в модели.
Записан
PavelVX
Гость
« Ответ #7 : Июль 13, 2012, 11:05 »

за 2 спасибо.
про 1. Видимо я плохо формулирую проблему.
есть view(k, f1, f2, f3), к ней вы прицепляете qtableview c моделью.
Понадобилось что-то изменить во вью и прибавить колонку, которую явно показывать не надо. Пока вы  не измените код, эта колонка будет видна. Можно ли автоматом скрывать колонки?
Записан
Странник
Гость
« Ответ #8 : Июль 13, 2012, 12:15 »

за 2 спасибо.
про 1. Видимо я плохо формулирую проблему.
есть view(k, f1, f2, f3), к ней вы прицепляете qtableview c моделью.
Понадобилось что-то изменить во вью и прибавить колонку, которую явно показывать не надо. Пока вы  не измените код, эта колонка будет видна. Можно ли автоматом скрывать колонки?

можете реализовать такое поведение сами. например:
Код:
//скрываете все колонки
for (int i = model->columnCount() - 1; i >= 0; i--)
    tableView->setColumnHidden(i, true);

//потом показываете только те, которые вам нужны
tableView->setColumnHidden(model->fieldIndex("k"), false);
tableView->setColumnHidden(model->fieldIndex("f1"), false);
tableView->setColumnHidden(model->fieldIndex("f2"), false);
tableView->setColumnHidden(model->fieldIndex("f3"), false);
Записан
PavelVX
Гость
« Ответ #9 : Июль 16, 2012, 11:17 »

Хмм, ну я несколько иначе это сделал, но мысль похожа на вашу. Спасибо.
Записан
PavelVX
Гость
« Ответ #10 : Август 29, 2012, 10:41 »

Уважаемые, направьте на путь истинный.
1.
Есть QSqlTableModel. Есть QLineEdit для фильтра.
QSqlTableModel->setFilter(QLineEdit->Text); //так мы задаем, что нужно отфильтровать.
QSqlTableModel->Select();
Но весь прикол в том, что я хочу получить фильтр в кэшированных данных! Без перезапроса в БД! Там тяжелая view и смысла нет таскать туда сюда данные. Как сделать фильтр без обращения к БД???
2. QSqlTableModel::OnManualSubmit
Как мне над полем QSqlTableModel сделать update? Типа захотелось мне все цены поднять на 5% и посмотреть на это до записи в базу.
Записан
Странник
Гость
« Ответ #11 : Август 29, 2012, 15:05 »

Уважаемые, направьте на путь истинный.
1.
Есть QSqlTableModel. Есть QLineEdit для фильтра.
QSqlTableModel->setFilter(QLineEdit->Text); //так мы задаем, что нужно отфильтровать.
QSqlTableModel->Select();
Но весь прикол в том, что я хочу получить фильтр в кэшированных данных! Без перезапроса в БД! Там тяжелая view и смысла нет таскать туда сюда данные. Как сделать фильтр без обращения к БД???
2. QSqlTableModel::OnManualSubmit
Как мне над полем QSqlTableModel сделать update? Типа захотелось мне все цены поднять на 5% и посмотреть на это до записи в базу.
1. использовать промежуточную QSortFilterProxyModel между вашими моделью и преставлением
2. при политике редактирования QSqlTableModel::OnManualSubmit используйте QSqlTableModel::setData(const QModelIndex & index, const QVariant & value, int role = Qt::EditRole) для изменения значения в модели, QSqlTableModel::submitAll() и QSqlTableModel::revertAll() для сохранения в базе и отката в модели соответственно.
Записан
PavelVX
Гость
« Ответ #12 : Август 30, 2012, 05:35 »

1. использовать промежуточную QSortFilterProxyModel между вашими моделью и преставлением - промежуточные слои, лишнее звено, соответственно лишние ошибки и тормоза.
2. при политике редактирования QSqlTableModel::OnManualSubmit используйте QSqlTableModel::setData(const QModelIndex & index, const QVariant & value, int role = Qt::EditRole) для изменения значения в модели, QSqlTableModel::submitAll() и QSqlTableModel::revertAll() для сохранения в базе и отката в модели соответственно. - это все понятно, но хотелось бы проделать и увидеть результат следующего действия без записи в базу
update QSqlTableModel set col1 = col1*1.05 where col2<10;
если я правильно тебя понял, то ты предлагаешь вручную обходить QSqlTableModel и менять значения, если надо. Правильно понял?
Просто я сравниваю с МС аксес. Там можно создать локальную табличку, слить в нее данные с БД, поизвращаться с ней как хочешь(delete, insert, update), посмотреть на резельтат, а потом, если захочешь, вернуть данные обратно. И быстро и удобно, и наглядно.
Записан
kataklysm
Гость
« Ответ #13 : Сентябрь 03, 2012, 14:26 »

Уважаемые, направьте на путь истинный.
1.
Есть QSqlTableModel. Есть QLineEdit для фильтра.
QSqlTableModel->setFilter(QLineEdit->Text); //так мы задаем, что нужно отфильтровать.
QSqlTableModel->Select();
Но весь прикол в том, что я хочу получить фильтр в кэшированных данных! Без перезапроса в БД! Там тяжелая view и смысла нет таскать туда сюда данные. Как сделать фильтр без обращения к БД???
1. Использовать QSqlTableModel::match() или использовать QCache
Записан
Alex_C
Гость
« Ответ #14 : Сентябрь 03, 2012, 15:45 »

Передо мной тоже вот стоит проблема аналогичная - организовать то, что называется MemoryTable. Подобных реализаций на том же Дельфи достаточно много. Конечно в идеале хочется, чтоб понимала хотя бы примитивный вариант SQL, но по большому счету нужна только сортировка и выборка.
Записан
Страниц: [1] 2   Вверх
  Печать  
 
Перейти в:  


Страница сгенерирована за 0.046 секунд. Запросов: 23.