CF
Cause FictionJuly 23, 2020, 4:47 p.m.

Qt + БД + TableModel

бд, Qt

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

Цель следующая - есть мой подкласс таблицы от QAbstractTableModel, который помещается на QTableView. В программе есть кнопка - Сохранить, до этого данные сохранялись в txt, как можно сделать, что-бы они сохранялись в базе данных, с возможностью потом загрузить? К примеру используя SQLite.
Интересует больше всего - как правильнее обратиться к созданному файлу БД при загрузке данных из него? Надо ли указывать путь до этого файла, и где?
Правильно ли вообще использовать QAbstractTableModel, или здесь правильнее QSqlTableModel ?
Если что я новичок, буду благодарен за простые и подробные ответы.

We recommend hosting TIMEWEB
We recommend hosting TIMEWEB
Stable hosting, on which the social network EVILEG is located. For projects on Django we recommend VDS hosting.

Do you like it? Share on social networks!

8
Evgenii Legotckoi
  • July 24, 2020, 3:09 a.m.

Добрый день.

Вы можете забрать все данные из своей модели, которая наследована от QAbstractTableModel, и сохранить все данные прямым запросом. Также можно использовать и QSqlTableModel.

Учитывая, что вы новичёк, то возможно вам стоит просто ознакомиться с какими-то статьями, которые здесь на сайте присутствуют.

Могу вам предложить посмотреть вот эти статьи, чтобы вы составили общее представление по работе с базами данных в Qt

    ИП
    • July 24, 2020, 3:44 a.m.

    При установке Qt в комплекте как правило идут примеры, в том числе там есть несколько примеров использования SQLite. Думаю если Вы справились с QAbstractTableModel + сохранением в файл и знаете что такое SQLite, то сразу все станет понятно.

      CF
      • July 24, 2020, 2:51 p.m.
      • (edited)

      Спасибо, правильно ли я мыслю, что если использовать подкласс QAbstractTableModel, то при сохранении данных в БД можно создать в ней таблицу на 3 столбца: (значение ячейки, строка, столбец) и сохранять туда ненулевые значения из программы ?
      И еще, как можно обратиться к моей БД для выгрузки данных из нее?

        Evgenii Legotckoi
        • July 24, 2020, 4:26 p.m.

        Если таблица не создана в базе данных, то её предварительно нужно создать. Я вам дал ссылки на статьи, в них используется класс DataBase, в котором есть пример кода для создания таблиц в базе данных SQLite, если таблицы ещё не существуют.
        Для редактирования данных в таблицах моно использовать QSqlTableModel.
        Что касается вопроса о выгрузке файлов из базы данных, то вы уверены, что там именно файлы хранятся? Может эти файлы ещё генерировать нужно из сщуествующих таблиц?

        И еще, как можно обратиться к моей БД для выгрузки файлов из нее?

        Этот ваш последний вопрос может потянуть по объяснению на несколько страниц текста и примеров програмного кода ого-го насколько.
        И при этом высока вероятность, что ответ окажется не тем, что предполагалось в сути вопроса.

        Просто начните что-то делать для начала. Создайте базу данных или подключитесь к существующей и отобразите таблицу.

          CF
          • July 24, 2020, 4:35 p.m.
          • (edited)

          Простите, я опечатался на счет файлов, хотел написать "данных". Я уже создал таблицу в БД, и сохраняю туда обычные значения. В папке сборки проекта создался файл my_DB.sqlite, и там есть моя таблица со всеми значениями. Вопрос в том, как в коде обратиться к этому файлу, что-бы получить мои данные обратно? (если я не использую QSqlTableModel)

          В статье нашел этот метод, это общий случай обращения к файлу БД ?

          bool DataBase::openDataBase()
          {
              /* База данных открывается по заданному пути
               * и имени базы данных, если она существует
               * */
              db = QSqlDatabase::addDatabase("QSQLITE");
              db.setHostName(DATABASE_HOSTNAME);
              db.setDatabaseName("C:/example/" DATABASE_NAME);
              if(db.open()){
                  return true;
              } else {
                  return false;
              }
          }
          
            Evgenii Legotckoi
            • July 24, 2020, 4:40 p.m.

            Вопрос в том, как в коде обратиться к этому файлу, что-бы получить мои данные обратно?

            Если вы хотите отобразить эти данные в виде таблице, то воспользуйтесь QSqlTableModel

            Вот я уже давал ссылку на статью Qt/C++ - Урок 004. QSqlTableModel или Как представить таблицу из БД в Qt?

            Я много времени тогда потратил, пока подготавливал её и писал. Не хочу повторяться.

            В той статье вам нужно внимательно просмотреть класс DataBase, в котором показано, как подключиться к базе данных SQLite.
            А также посмотрите, как работать с самой QSqlTableModel и QTableView, чтобы отобразить данные.

            Если вы как-то ещё хотите получать данные, и как-то иначе с ними работать, а не только в таблице, то уточните.

            Вопрос в том, как в коде обратиться к этому файлу, что-бы получить мои данные обратно?

            Но по факту в той статье есть ответ на этот вопрос. Он в классе DataBase. Там показано подключение к базе данных.

              Evgenii Legotckoi
              • July 24, 2020, 4:48 p.m.

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

                CF
                • July 24, 2020, 8:47 p.m.

                Хорошо, большое спасибо

                  Comments

                  Only authorized users can post comments.
                  Please, Log in or Sign up
                  d
                  • dsfs
                  • April 26, 2024, 2:56 p.m.

                  C ++ - Test 004. Pointers, Arrays and Loops

                  • Result:80points,
                  • Rating points4
                  d
                  • dsfs
                  • April 26, 2024, 2:45 p.m.

                  C++ - Test 002. Constants

                  • Result:50points,
                  • Rating points-4
                  d
                  • dsfs
                  • April 26, 2024, 2:35 p.m.

                  C++ - Test 001. The first program and data types

                  • Result:73points,
                  • Rating points1
                  Last comments
                  k
                  kmssrFeb. 9, 2024, 5:43 a.m.
                  Qt Linux - Lesson 001. Autorun Qt application under Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
                  Qt WinAPI - Lesson 007. Working with ICMP Ping in Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
                  EVA
                  EVADec. 25, 2023, 9:30 p.m.
                  Boost - static linking in CMake project under Windows Ошибка LNK1104 часто возникает, когда компоновщик не может найти или открыть файл библиотеки. В вашем случае, это файл libboost_locale-vc142-mt-gd-x64-1_74.lib из библиотеки Boost для C+…
                  J
                  JonnyJoDec. 25, 2023, 7:38 p.m.
                  Boost - static linking in CMake project under Windows Сделал всё по-как у вас, но выдаёт ошибку [build] LINK : fatal error LNK1104: не удается открыть файл "libboost_locale-vc142-mt-gd-x64-1_74.lib" Хоть убей, не могу понять в чём дел…
                  G
                  GvozdikDec. 19, 2023, 8:01 a.m.
                  Qt/C++ - Lesson 056. Connecting the Boost library in Qt for MinGW and MSVC compilers Для решения твой проблемы добавь в файл .pro строчку "LIBS += -lws2_32" она решит проблему , лично мне помогло.
                  Now discuss on the forum
                  G
                  GarApril 22, 2024, 3:46 p.m.
                  Clipboard Как скопировать окно целиком в clipb?
                  DA
                  Dr Gangil AcademicsApril 20, 2024, 5:45 p.m.
                  Unlock Your Aesthetic Potential: Explore MSC in Facial Aesthetics and Cosmetology in India Embark on a transformative journey with an msc in facial aesthetics and cosmetology in india . Delve into the intricate world of beauty and rejuvenation, guided by expert faculty and …
                  a
                  a_vlasovApril 14, 2024, 4:41 p.m.
                  Мобильное приложение на C++Qt и бэкенд к нему на Django Rest Framework Евгений, добрый день! Такой вопрос. Верно ли следующее утверждение: Любое Android-приложение, написанное на Java/Kotlin чисто теоретически (пусть и с большими трудностями) можно написать и на C+…
                  Павел Дорофеев
                  Павел ДорофеевApril 14, 2024, 12:35 p.m.
                  QTableWidget с 2 заголовками Вот тут есть кастомный QTableView с многорядностью проект поддерживается, обращайтесь
                  f
                  fastrexApril 4, 2024, 2:47 p.m.
                  Вернуть старое поведение QComboBox, не менять индекс при resetModel Добрый день! У нас много проектов в которых используется QComboBox, в версии 5.5.1, когда модель испускает сигнал resetModel, currentIndex не менялся. В версии 5.15 при resetModel происходит try…

                  Follow us in social networks