l
ladaisakovaЖел. 23, 2017, 7:23 Т.Ж.

database not open

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

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

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

10
Evgenii Legotckoi
  • Жел. 23, 2017, 3:39 Т.Қ.

День добрый.

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

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

    а саму базу через путь к файлу
    в двух окнах открывается, в остальных нет
      Evgenii Legotckoi
      • Жел. 23, 2017, 3: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, 4:03 Т.Қ.

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

          Evgenii Legotckoi
          • Жел. 23, 2017, 4:12 Т.Қ.

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

            l
            • Жел. 23, 2017, 4:16 Т.Қ.

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

              Evgenii Legotckoi
              • Жел. 23, 2017, 4:21 Т.Қ.
              • (өңделген)

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


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

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

                  l
                  • Жел. 24, 2017, 8:33 Т.Ж.

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

                    Evgenii Legotckoi
                    • Жел. 26, 2017, 4:16 Т.Ж.

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

                      Пікірлер

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

                      C++ - Тест 001. Первая программа и типы данных

                      • Нәтиже:66ұпай,
                      • Бағалау ұпайлары-1
                      t

                      C++ - Тест 001. Первая программа и типы данных

                      • Нәтиже:33ұпай,
                      • Бағалау ұпайлары-10
                      t

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

                      • Нәтиже:52ұпай,
                      • Бағалау ұпайлары-4
                      Соңғы пікірлер
                      G
                      GoattRockҚыр. 3, 2024, 1:50 Т.Қ.
                      Linux жүйесінде файлдарды қалай көшіруге болады Задумывались когда-нибудь о том, как мы привыкли доверять свои вещи службам грузоперевозок? Сейчас такие услуги стали неотъемлемой частью нашей жизни, особенно когда речь идет о переездах между …
                      d
                      dblas5Шілде 5, 2024, 11:02 Т.Ж.
                      QML - Сабақ 016. SQLite деректер қоры және онымен QML Qt-та жұмыс істеу Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
                      k
                      kmssrАқп. 8, 2024, 6:43 Т.Қ.
                      Qt Linux - Сабақ 001. Linux астында Autorun Qt қолданбасы как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
                      АК
                      Анатолий КононенкоАқп. 5, 2024, 1:50 Т.Ж.
                      Qt WinAPI - Сабақ 007. Qt ішінде ICMP Ping арқылы жұмыс істеу Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
                      Енді форумда талқылаңыз
                      Evgenii Legotckoi
                      Evgenii LegotckoiМаусым 24, 2024, 3:11 Т.Қ.
                      добавить qlineseries в функции Я тут. Работы оень много. Отправил его в бан.
                      F
                      FynjyШілде 22, 2024, 4:15 Т.Ж.
                      при создании qml проекта Kits есть но недоступны для выбора Поставил Qt Creator 11.0.2. Qt 6.4.3 При создании проекта Qml не могу выбрать Kits, они все недоступны, хотя настроены и при создании обычного Qt Widget приложения их можно выбрать. В чем может …
                      BlinCT
                      BlinCTМаусым 25, 2024, 1 Т.Ж.
                      Нарисовать кривую в qml Всем привет. Имеется Лист листов с тосками, точки получаны интерполяцией Лагранжа. Вопрос, как этими точками нарисовать кривую? ChartView отпадает сразу, в qt6.7 появился новый элемент…
                      BlinCT
                      BlinCTМамыр 5, 2024, 5:46 Т.Ж.
                      Написать свой GraphsView Всем привет. В Qt есть давольно старый обьект дял работы с графиками ChartsView и есть в 6.7 новый но очень сырой и со слабым функционалом GraphsView. По этой причине я хочу написать х…
                      Evgenii Legotckoi
                      Evgenii LegotckoiМамыр 2, 2024, 2:07 Т.Қ.
                      Мобильное приложение на C++Qt и бэкенд к нему на Django Rest Framework Добрый день. По моему мнению - да, но то, что будет касаться вызовов к функционалу Андроида, может создать огромные трудности.

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