АЗ
Aug. 4, 2016, 7:56 p.m.

Не понятное поведение QSqlTableModel

QAbstractListModel, QPSQL, QSqlTableModel

Евгений, добрый день. Всю голову сломал, но так ответа и не нашел. Есть конечно какие-то у меня предположения, но что-то совсем из области фантастики.

В архиве очень простенький пример этой проблемы. А проблема такая.

Создаю простое подключение в БД с драйвером QPSQL все работает и все подключается. Создаю model = new QSqlTqbleModel(this, bd); и пытаюсь представить ее в listView и tableView, но ни там ни там этого не происходит, хотя данные с сервера идут и в qDebug я их вывожу.

Дальше интересней. Коментируем подключение через QPSQL и ставим QSQLITE. Больше ничего не меняем… и все отображается.

Ну и верх моего удивления. Возвращаем все обратно, т.е. QPSQL и делаем через QAbstractListModel – все отображается и работает.

Подскажите, где у меня пробел в голове?

0

Do you like it? Share on social networks!

7
Evgenii Legotckoi
  • Aug. 9, 2016, 3:02 a.m.

День добрый, Андрей.

Вообще, не обязательно передавать базу данных в следующей строке (Там по умолчанию будет подставлено всё, что нужно):
model = new QSqlTableModel(this, db);

В заголовочном файле меня напрягает, что набор директив #define немного различный, хотя это скорее всего и не принципиально. А вот по остальному, нужно смотреть, что вы сделали в приложенном архиве. Я увеличил размер вложений до 500 кБ. Нужно смотреть проект в целом. А вообще, скорее всего какая-то ошибка в инициализации или вообще отсутствие искомых таблиц при первом обращении.

    Евгений а можете увеличить до 800 а то архив получается 769kb
      АЗ
      • Aug. 9, 2016, 9:34 a.m.
      хотя там в архиве то и нет ни чего ценного. только файлы по умолчанию. и вот те что в начале передал.
        Evgenii Legotckoi
        • Aug. 9, 2016, 10:50 p.m.
        Увеличил до 1-го мегабайта.
        У вас получается Postgresql используется? Довольно сумбурное описание проблемы. Больше похоже на то, что в процессе редактирования где-то была допущена небольшая ошибка. Вроде отсутствия точки с запятой в SQL запросе или что-то ещё подобное.

          Вот оно. Чудо))

          untitled.zip

            Evgenii Legotckoi
            • Aug. 11, 2016, 1:22 a.m.
            Полагаю, что всё же косяк с применением QSqlTableModel был.
            Приложенный код должен быть рабочим. Может быть ошибка в самой таблице.
              Вот в этом то и парадокс, что таблица тоже рабочая. Ставлю вместо обычной модели свою. И вуаля все работает. Сам код то не меняю. просто подключаю свою модель. Ладно буду разбираться. Наверное где-то что-то упустил. Спасибо огромное за ваш труд.

                Comments

                Only authorized users can post comments.
                Please, Log in or Sign up
                • Last comments
                • AK
                  April 1, 2025, 11:41 a.m.
                  Добрый день. В данный момент работаю над проектом, где необходимо выводить звук из программы в определенное аудиоустройство (колонки, наушники, виртуальный кабель и т.д). Пишу на Qt5.12.12 поско…
                • Evgenii Legotckoi
                  March 9, 2025, 9:02 p.m.
                  К сожалению, я этого подсказать не могу, поскольку у меня нет необходимости в обходе блокировок и т.д. Поэтому я и не задавался решением этой проблемы. Ну выглядит так, что вам действитель…
                • VP
                  March 9, 2025, 4:14 p.m.
                  Здравствуйте! Я устанавливал Qt6 из исходников а также Qt Creator по отдельности. Все компоненты, связанные с разработкой для Android, установлены. Кроме одного... Когда пытаюсь скомпилиров…
                • ИМ
                  Nov. 22, 2024, 9:51 p.m.
                  Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
                • Evgenii Legotckoi
                  Oct. 31, 2024, 11:37 p.m.
                  Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup