l
ladaisakova23 грудня 2017 р. 07:23

database not open

Здравствуйте, qt использую первый раз, для курсовой работы. Столкнулась с проблемой: в шести окнах я обращаюсь к базе данных, но только в двух все работает. При работе с остальными пишет database not open, хотя синтаксис везде аналогичный. Не могу разобраться :(

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

Вам це подобається? Поділіться в соціальних мережах!

10
Evgenii Legotckoi
  • 23 грудня 2017 р. 15:39

День добрый.

Если пишет database not open, значит вы не открываете соединение с базой данных по какой-то причине. По идее там в примере в файле main.cpp
// Подключаемся к базе данных
DataBase database;
database.connectToDataBase();
Но у вас по какой-то причине это соединение закрывается. Вы используете базу данных SQLite?
    l
    • 23 грудня 2017 р. 15:45

    Работаю с SQLite, но я не прописываю класс database
    я просто в каждом окне делаю #include "QSqlQuery" #include "QtSql/QSqlDatabase"

    а саму базу через путь к файлу
    в двух окнах открывается, в остальных нет
      Evgenii Legotckoi
      • 23 грудня 2017 р. 15:59

      Тогда странно, что вообще открывается в двух окнах.

      Видите ли, без открытого подключения к базе данных нет возможности ни читать, ни записывать ничего.
      А за открытие базы данных фактически отвечает следующий код во вспомогательном классе базы данных.
      Конкретно вот этот метод
      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;
          }
      }
        l
        • 23 грудня 2017 р. 16:03

        Дело в том, что тот фрагмент кода, который Вы привели, я прописываю в конструкторе в cpp для каждого окна, где мне требуется база. Не понимаю, в чем проблема:(

          Evgenii Legotckoi
          • 23 грудня 2017 р. 16:12

          Многократная попытка открытия базы данных уже открытой базы данных. Базу данных нужно или закрывать. или держать открытой в течение всего жизненного цикла. Попробуйте сделать коннект к базе данных один раз в файле main.cpp

            l
            • 23 грудня 2017 р. 16:16

            Спасибо за совет! а как сделать так, чтобы в других окнах эта база была видна?
            ее нужно будет как-то объявлять в cpp, где она буде использоваться?

              Evgenii Legotckoi
              • 23 грудня 2017 р. 16:21
              • (відредаговано)

              Фактически объявлять в других местах кода её не нужно. В самых внутренностях Qt, в приватных классах, которые скрыты от пользователя, хранится что-то вроде вектора (контейнер), который хранит информацию о всех базах данных. После того, как база данных открыта, можно использовать QSqlQuery и другие классы без объявления заголовочного файла данного вспомогательного класса, если конечно, вы не добавили туда дополнительную вспомогательную логику.


              То есть после открытия базы данных например в main.cpp файле, можете спокойно использовать QSqlQuery в других местах кода. Это должно работать.
                l
                • 23 грудня 2017 р. 16:27

                спасибо) попробую

                  l
                  • 24 грудня 2017 р. 08:33

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

                    Evgenii Legotckoi
                    • 26 грудня 2017 р. 04:16

                    Тут уже код смотреть нужно, чтобы понять причину.

                      Коментарі

                      Only authorized users can post comments.
                      Please, Log in or Sign up
                      AD

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

                      • Результат:50бали,
                      • Рейтинг балів-4
                      m
                      • molni99
                      • 26 жовтня 2024 р. 01:37

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

                      • Результат:80бали,
                      • Рейтинг балів4
                      m
                      • molni99
                      • 26 жовтня 2024 р. 01:29

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

                      • Результат:20бали,
                      • Рейтинг балів-10
                      Останні коментарі
                      ИМ
                      Игорь Максимов22 листопада 2024 р. 11:51
                      Django - Підручник 017. Налаштуйте сторінку входу до Django Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
                      Evgenii Legotckoi
                      Evgenii Legotckoi31 жовтня 2024 р. 14:37
                      Django - Урок 064. Як написати розширення для Python Markdown Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup
                      A
                      ALO1ZE19 жовтня 2024 р. 08:19
                      Читалка файлів fb3 на Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
                      ИМ
                      Игорь Максимов05 жовтня 2024 р. 07:51
                      Django - Урок 064. Як написати розширення для Python Markdown Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
                      d
                      dblas505 липня 2024 р. 11:02
                      QML - Урок 016. База даних SQLite та робота з нею в QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
                      Тепер обговоріть на форумі
                      Evgenii Legotckoi
                      Evgenii Legotckoi24 червня 2024 р. 15:11
                      добавить qlineseries в функции Я тут. Работы оень много. Отправил его в бан.
                      t
                      tonypeachey115 листопада 2024 р. 06:04
                      google domain [url=https://google.com/]domain[/url] domain [http://www.example.com link title]
                      NSProject
                      NSProject04 червня 2022 р. 03:49
                      Всё ещё разбираюсь с кешем. В следствии прочтения данной статьи. Я принял для себя решение сделать кеширование свойств менеджера модели LikeDislike. И так как установка evileg_core для меня не была возможна, ибо он писался…
                      9
                      9Anonim25 жовтня 2024 р. 09:10
                      Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…

                      Слідкуйте за нами в соціальних мережах