VB
Vladimir BervinҚаз. 30, 2020, 6: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, 7:29 Т.Ж.
  • (өңделген)

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

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

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

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

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

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

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

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

          Алексей Внуков
          • Қаз. 30, 2020, 8: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, 9:01 Т.Ж.

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

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

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

              QList<Data*> items;
              

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

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

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

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

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

                    Пікірлер

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

                    C++ - Тест 004. Указатели, Массивы и Циклы

                    • Нәтиже:50ұпай,
                    • Бағалау ұпайлары-4
                    m
                    • molni99
                    • Қаз. 26, 2024, 1:37 Т.Ж.

                    C++ - Тест 004. Указатели, Массивы и Циклы

                    • Нәтиже:80ұпай,
                    • Бағалау ұпайлары4
                    m
                    • molni99
                    • Қаз. 26, 2024, 1:29 Т.Ж.

                    C++ - Тест 004. Указатели, Массивы и Циклы

                    • Нәтиже:20ұпай,
                    • Бағалау ұпайлары-10
                    Соңғы пікірлер
                    ИМ
                    Игорь МаксимовҚар. 22, 2024, 11:51 Т.Ж.
                    Django - Оқулық 017. Теңшелген Django кіру беті Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
                    Evgenii Legotckoi
                    Evgenii LegotckoiҚаз. 31, 2024, 2:37 Т.Қ.
                    Django - Сабақ 064. Python Markdown кеңейтімін қалай жазуға болады Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup
                    A
                    ALO1ZEҚаз. 19, 2024, 8:19 Т.Ж.
                    Qt Creator көмегімен fb3 файл оқу құралы Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
                    ИМ
                    Игорь МаксимовҚаз. 5, 2024, 7:51 Т.Ж.
                    Django - Сабақ 064. Python Markdown кеңейтімін қалай жазуға болады Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
                    d
                    dblas5Шілде 5, 2024, 11:02 Т.Ж.
                    QML - Сабақ 016. SQLite деректер қоры және онымен QML Qt-та жұмыс істеу Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
                    Енді форумда талқылаңыз
                    m
                    moogoҚар. 22, 2024, 7:17 Т.Ж.
                    Mosquito Spray System Effective Mosquito Systems for Backyard | Eco-Friendly Misting Control Device & Repellent Spray - Moogo ; Upgrade your backyard with our mosquito-repellent device! Our misters conce…
                    Evgenii Legotckoi
                    Evgenii LegotckoiМаусым 24, 2024, 3:11 Т.Қ.
                    добавить qlineseries в функции Я тут. Работы оень много. Отправил его в бан.
                    t
                    tonypeachey1Қар. 15, 2024, 6:04 Т.Ж.
                    google domain [url=https://google.com/]domain[/url] domain [http://www.example.com link title]
                    NSProject
                    NSProjectМаусым 4, 2022, 3:49 Т.Ж.
                    Всё ещё разбираюсь с кешем. В следствии прочтения данной статьи. Я принял для себя решение сделать кеширование свойств менеджера модели LikeDislike. И так как установка evileg_core для меня не была возможна, ибо он писался…

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