VB
Vladimir BervinҚаз. 30, 2020, 4:32 Т.Қ.

Лишние строки при выборке из базы данных SQLite

Добрый день. Надеюсь, кто-то знает ответ.
Почему если в модели унаследованной от QSqlTableModel в следующем коде использовать

setQuery(qry);

то в представлении появляются пустые строчки, которые в целом не мешают, но их становится всё больше и больше.
Если же использовать вместо этого

    beginResetModel();
    endResetModel();

то, лишних строчек нет.

Сам код

void Model::selectAll()
{
    items->clear();
    QSqlQuery qry;
    qry.prepare(
                "SELECT                   \n"
                "   id,                        \n"
                "   code,             \n"
                "   date,                  \n"
                "   person,                  \n"
                "   description                  \n"
                "   FROM myDB          \n"
                "   ORDER BY code DESC;   \n"
                );

    if(qry.exec()){
        while(qry.next()){
            Data *item = new Data(this, qry);
            addItem(item);
        }
    } else {
        qCritical() << "Cannot execute query!";
        QSqlError err = qry.lastError();
        qCritical() << err.nativeErrorCode();
        qCritical() << err.databaseText().toUtf8().data();
        qCritical() << err.driverText().toUtf8().data();
        qDebug() << qry.executedQuery();
    }

//    setQuery(qry);
    beginResetModel();
    endResetModel();
}

Причем если вставить qDebug() << Items->Id();, то количество элементов будет то, какое должно быть.

Рекомендуем хостинг TIMEWEB
Рекомендуем хостинг TIMEWEB
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.

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

9
ИП
  • Қаз. 30, 2020, 5:29 Т.Қ.
  • (өңделген)

Как-то странно Вы используйте наследование от QSqlTableModel и еще используйте в нем QSqlQuery...
А чем обычный QSqlTableModel не устраивает для вывода всех данных из обной таблицы?

    Алексей Внуков
    • Қаз. 30, 2020, 5:32 Т.Қ.
    • (өңделген)

    а как вообще создаете модель? и зачам вам там обьект класса Data и что это за класс? если в базе нет пустых строк, то скорее всего у вас ошибки в реализации модели. и почему наследываетесь от QSqlTableModel а не от тойже QSqlQueryModel?

    и вообще, как и в каких целях планируете использовать модель?

      VB
      • Қаз. 30, 2020, 5:42 Т.Қ.
      • (өңделген)

      QSqlTableModel не удаётся редактировать и удалять данные - вот здесь есть исходный код прототипа этого проекта. ( Код )
      Класс Data содержит данные. Наследуюсь от QSqlTableModel, так как меняю данные в базе данных, добавляю элементы и редактирую их, удаление почему-то не работает. Класс QSqlQueryModel, как я понял, больше подходит для отображения данных, а не для редактирования.

        VB
        • Қаз. 30, 2020, 5:45 Т.Қ.
        • (өңделген)

        Я практик, правил не знаю, если код работает, то хорошо. Данный проект работает без видимых ошибок. Проблему лишних строк решил заменой, о которой в данном посте написал. Я просто хочу понять почему всё же лишние строки образуются. В базе данных 288 элементов и уже 32 лишние строки.

          Алексей Внуков
          • Қаз. 30, 2020, 6:49 Т.Қ.
          • (өңделген)

          все равно моя не понимать.
          во первых зачем делать перенос на новую строку после каждого слова в запросе? некоторые БД могут не корректно отработать запрос только от того что он не так создался, а лишние символы уж подавно

                          "SELECT                   \n"
                          "   id,                        \n"
                          "   code,             \n"
                          "   date,                  \n"
                          "   person,                  \n"
                          "   description                  \n"
                          "   FROM myDB          \n"
                          "   ORDER BY code DESC;   \n"
          

          во вторых: чем вас не устоил, как уже было замечено, стандартнй QSqlTableModel? что вы пытаетесь сделать с Data, и зачем он нужен? QSqlTableModel позволяет на прямую редактировать.
          вы всеравно выполняете редактирование и сохранение в обход QSqlTableModel. зачем вы на столько усложняете себе код?

          bool Model::save_to_db(Data *item)
          {   
              QSqlQuery query;
              query.setForwardOnly(true);
          
              query.prepare("INSERT INTO myDB (code, date, person, description)"
                                        "VALUES (:code, :date, :person, :description)");
          
              query.bindValue(":code", item->Code());
              query.bindValue(":date", item->Date());
              query.bindValue(":person", item->Person());
              query.bindValue(":description", item->Description());
          
              if(query.exec()) return true;
          
              qCritical() << query.lastError().databaseText();
              qCritical() << query.lastError().driverText();
              qCritical() << query.lastError().nativeErrorCode();
          
              return false;
          }
          
            Алексей Внуков
            • Қаз. 30, 2020, 7:01 Т.Қ.

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

              VB
              • Қаз. 30, 2020, 11:52 Т.Қ.
              • (өңделген)

              Не понятно что значит редактировать и добавлять в обход QSqlTableModel. Как я понял, процесс добавления или редактирования, это сначала добавляем и редактируем модель, потом добавляем или редактируем базу. В моём коде это последовательно и делается. База же не поменяется, если я отредактирую только модель. А Data это класс экземпляра данных. В модели список указателей и методов.

              QList<Data*> items;
              

              Доступ к элементу данных и переопределённые методы QSqlTableModel для вывода в представление.
              Редактирую элемент в списке, затем произвожу изменения в базе. Какая еще может быть логика?

                VB
                • Қаз. 30, 2020, 11:59 Т.Қ.

                Ну вообще совсем без знания документации трудно что-либо написать. Я просмотрел видеокурс по моделям в Qt, несколько видеоуроков. Немного почитал документацию. Понятно, что где-то не понятно как использовать все возможности класса QSqlTableModel.

                  Алексей Внуков
                  • Қар. 2, 2020, 4 Т.Қ.

                  можно сразу редактируя ячейку в виджете, будет редактироваться запись в базе. и тогда не нужны все манипуляции с классом Data

                    Пікірлер

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

                    Qt - Тест 001. Сигналы и слоты

                    • Нәтиже:84ұпай,
                    • Бағалау ұпайлары4
                    Ua

                    Qt - Тест 001. Сигналы и слоты

                    • Нәтиже:42ұпай,
                    • Бағалау ұпайлары-8
                    ОК

                    Qt - Тест 001. Сигналы и слоты

                    • Нәтиже:47ұпай,
                    • Бағалау ұпайлары-6
                    Соңғы пікірлер
                    ИМ
                    Игорь МаксимовҚар. 22, 2024, 9:51 Т.Қ.
                    Django - Оқулық 017. Теңшелген Django кіру беті Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
                    Evgenii Legotckoi
                    Evgenii LegotckoiҚаз. 31, 2024, 11:37 Т.Қ.
                    Django - Сабақ 064. Python Markdown кеңейтімін қалай жазуға болады Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup
                    A
                    ALO1ZEҚаз. 19, 2024, 5:19 Т.Қ.
                    Qt Creator көмегімен fb3 файл оқу құралы Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
                    ИМ
                    Игорь МаксимовҚаз. 5, 2024, 4:51 Т.Қ.
                    Django - Сабақ 064. Python Markdown кеңейтімін қалай жазуға болады Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
                    d
                    dblas5Шілде 5, 2024, 8:02 Т.Қ.
                    QML - Сабақ 016. SQLite деректер қоры және онымен QML Qt-та жұмыс істеу Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
                    Енді форумда талқылаңыз
                    f
                    firstlunoxodАқп. 15, 2025, 1:46 Т.Қ.
                    Рисование на QGraphicsScene при зажатой кнопке мыши Подскажите, пожалуйста! Как данный класс можно дополнить, чтобы созданные объекты можно было перемещать мышкой по сцене?
                    Дмитрий
                    ДмитрийАқп. 3, 2025, 4:24 Т.Қ.
                    Создание deb-пакета. Как создать ярлык на рабочем столе после установки собственного deb-пакета? Всем привет. Сделал свой deb-пакет с программой. Всё устанавливается и работает. Ставлю по пути /usr/bin/my_application. Как для пользователя при установке пакета сразу создать ярлык на раб…
                    NW
                    Nayo WaiҚаң. 30, 2025, 7:22 Т.Қ.
                    не запускается компьютер!!! Не запускается компьютер (точнее работает блок , но сам монитор вообще жесть)В общем я ничего с интернета не скачивала в последнее время. На компе никаких левых пр…
                    n
                    nklyҚаң. 3, 2025, 12:52 Т.Қ.
                    Нужно запретить перемещение только некоторых итемов, остальные перемещать можно. Вопрос решен. Узнать QModelIndex элемента на который мы перетаскиваем другой элемент, можно с помощью функции indexAt(event->position().toPoint()) представления QTreeViev вызываемой в переопр…
                    M
                    MarselТам. 17, 2023, 12:26 Т.Ж.
                    OAuth2.0 через VK, получение email Спасибо большое за помощь и простите за то что отнял время своей невнимательностью.

                    Бізді әлеуметтік желілерде бақылаңыз