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
                  AD

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

                  • Result:50points,
                  • Rating points-4
                  m

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

                  • Result:80points,
                  • Rating points4
                  m

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

                  • Result:20points,
                  • Rating points-10
                  Last comments
                  i
                  innorwallNov. 14, 2024, 12:07 p.m.
                  Circuit switching and packet data transmission networks Angioedema 1 priligy dapoxetine
                  i
                  innorwallNov. 14, 2024, 11:42 a.m.
                  How to Copy Files in Linux If only females relatives with DZ offspring were considered these percentages were 23 order priligy online uk
                  i
                  innorwallNov. 14, 2024, 9:09 a.m.
                  Qt/C++ - Tutorial 068. Hello World using the CMAKE build system in CLion ditropan pristiq dosing With the Yankees leading, 4 3, Rivera jogged in from the bullpen to a standing ovation as he prepared for his final appearance in Chicago buy priligy pakistan
                  i
                  innorwallNov. 14, 2024, 4:05 a.m.
                  EVILEG-CORE. Using Google reCAPTCHA 2001; 98 29 34 priligy buy
                  i
                  innorwallNov. 14, 2024, 4 a.m.
                  PyQt5 - Lesson 007. Works with QML QtQuick (Signals and slots) priligy 30mg Am J Obstet Gynecol 171 1488 505
                  Now discuss on the forum
                  i
                  innorwallNov. 14, 2024, 3:39 a.m.
                  добавить qlineseries в функции priligy amazon canada 93 GREB1 protein GREB1 AB011147 6
                  i
                  innorwallNov. 11, 2024, 10:55 a.m.
                  Всё ещё разбираюсь с кешем. priligy walgreens levitra dulcolax carbs The third ring was found to be made up of ultra relativistic electrons, which are also present in both the outer and inner rings
                  9
                  9AnonimOct. 25, 2024, 9:10 a.m.
                  Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…

                  Follow us in social networks