АЗ
Там. 4, 2016, 7:56 Т.Қ.

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

QAbstractListModel, QPSQL, QSqlTableModel

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

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

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

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

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

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

0

Ол саған ұнайды ма? Әлеуметтік желілерде бөлісіңіз!

7
Evgenii Legotckoi
  • Там. 9, 2016, 3:02 Т.Ж.

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

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

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

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

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

          untitled.zip

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

                Пікірлер

                Тек рұқсаты бар пайдаланушылар ғана пікір қалдыра алады.
                Кіріңіз немесе Тіркеліңіз