Михаиллл
МихаилллҚар. 10, 2018, 10:47 Т.Ж.

через QT не могу открыть файл SQLite

Qt, SQLite

Добрый день.

Я создал  в SQLiteStudio базу данных.

Пытаюсь открыть ее в QT этим кодом

QSqlDatabase ResumeDB; //resume sql
ResumeDB.setDatabaseName("C:\\CVReader\\ResumeArraySQLite.db");

if (!ResumeDB.open()) {qDebug()<<"not open";}


дебаг выдает "not open"

Не знаете, где ошибка и как открыть?

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

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

15
R
  • Қар. 10, 2018, 10:59 Т.Ж.
  • Жауап шешім ретінде белгіленді.
    QSqlDatabase dbcache = QSqlDatabase::addDatabase("QSQLITE", "cache");
    dbcache.setDatabaseName("/dbc.db3");


    if (!dbcache.open()) {
        qDebug() << "error connect to database" << dbcache.lastError().text();
        return false;
    }
    Михаиллл
    • Қар. 10, 2018, 11:41 Т.Ж.
    • (өңделген)

    Спасибо.

    И еще вопрос, пытаюсь использовать запрос exec, но выдает ошибку QSqlQuery::exec: database not open

    код такой


    QSqlQuery query;
            query.exec("INSERT INTO SQLliteResumeArray ("
                       "Name,"
                       "Gender,"
                       "Age,"
                       "DateOfBirth,"
                       "PhoneNumber,"
                       "Email,"
                       "City,"
                       "PostDesired,"
                       "Salary,"
                       "CVPost,"
                       "NameCompany,"
                       "Experiance,"
                       "Languages,"
                       "AdditionalInformation,"
                       "Education,"
                       "Skills,"
                       "Comments,"
                       "Resume)"
                   "VALUES ("
                       "'NameFromResume',"
                       "'GenderFromResume',"
                       "AgeFromResume,"
                       "'DateOfBirthQString',"
                       "'PhoneNumberFromResume',"
                       "'MailFromResume',"
                       "'CityFromResume',"
                       "'PostDesiredFromResume',"
                       "SalaryFromResume,"
                       "'CVPostFromResume',"
                       "'CompanyFromResume',"
                       "'ExperianceFromResume',"
                       "'LanguagesFromResume',"
                       "'AdditionInformationFromResume',"
                       "'EducanionFromResume',"
                       "'SkillsFromResume',"
                       "'CommentsFromResume',"

                       "'TextResume');");
      R
      • Қар. 10, 2018, 11:51 Т.Ж.

      прочитай хотя бы это

      http://www.java2s.com/Code/Cpp/Qt/UsingsqldatabasefromQt.htm

          QSqlQuery m_query(QSqlDatabase::database("cache"));
          m_query.prepare("INSERT INTO name_table (id_item)"
                          " VALUES (:id_item)");
      
      
          m_query.bindValue(":id_item", idItem());
      
      
          if(!m_query.exec())
          {
              qDebug() << Q_FUNC_INFO << m_query.lastError();
          }

        Михаиллл
        • Қар. 11, 2018, 8:37 Т.Ж.

        спасибо , читаю.

        но почему у меня не верно?

        тут https://doc.qt.io/qt-5.11/qsqlquery.html#exec также написано.

        их пример

        QSqlQuery query;
            query.exec("INSERT INTO employee (id, name, salary) "
                       "VALUES (1001, 'Thad Beaumont', 65000)");

          Михаиллл
          • Қар. 11, 2018, 8:49 Т.Ж.

          и скажите пожалуйста, что такое cache

            Михаиллл
            • Қар. 11, 2018, 8:52 Т.Ж.

            и по предложенной Вами ссылки также делают

                QSqlQuery query;
                query.prepare("INSERT INTO person (id, forename, surname) ""VALUES (:id, :forename, :surname)");
              R
              • Қар. 11, 2018, 9:03 Т.Ж.
              • (өңделген)

              cache это название соединения

              можно так

               QSqlDatabase dbcache = QSqlDatabase::addDatabase("QSQLITE");

              тогда будет какая-то базовая название соединения


              если я не ошибаюсь вот так будет работать твой вариант, так как при таком, ты не передаешь соединения для квери

              QSqlQuery query;



                Михаиллл
                • Қар. 11, 2018, 10:34 Т.Ж.

                Сделал тренировочную таблицу. Если вот так писать, то при первом запросе нет ошибок, но при повторе действия выдает ошибку QSqlDatabasePrivate::addDatabase: duplicate connection name 'qt_sql_default_connection', old connection removed.

                  QSqlDatabase TestDB = QSqlDatabase::addDatabase("QSQLITE"); //resume sql
                        TestDB.setDatabaseName("/TestSQLite.db");
                        //TestDB.open();
                        if (!TestDB.open()) {qDebug()<<"not open";}
                        QSqlQuery query;       
                                query.exec("INSERT INTO TestSQL ("
                                          // "NumberID,"
                                           "TestInt,"
                                           "TestStr"
                                       ")"
                                       "VALUES ("
                                           //"'1',"
                                           "'2',"
                                           "'TestStr'"
                                       ");");

                        qDebug()<<"наверно записалось";

                        TestDB.close();

                Смотрел в редакторе SQL, данные не добавляются.

                Подскажите пожалуйста, что не так.

                  Михаиллл
                  • Қар. 11, 2018, 10:49 Т.Ж.

                  и если делать так, тоже  не работает


                   query.prepare("INSERT INTO TestSQL ("
                                         "TestInt,"
                                     ")"
                                     "VALUES ("
                                         ":IntTest,"
                                     ");");
                          query.bindValue(":IntTest",123);

                          query.exec();
                    R
                    • Қар. 11, 2018, 10:52 Т.Ж.

                    мені по російски важко писати тому, моежш перкласти ))))



                    помилка виникає тому що ти намагаєшся створити ще одне з'єднання з такоюж назвою, щоб це зробити спочатку потрібно видалити старе з'єднання

                    QSqlDatabase::removeDatabase(name_connect);


                    ти можеш зробити так

                    QSqlDatabase TestDB = QSqlDatabase::addDatabase("QSQLITE", "connect_db"); 


                    ........

                    QSqlDatabase::removeDatabase("connect_db");



                    якщо у вас плануєтсяь виокористовувати одну базу то яб просто встановив  зєднання десь на початку програми і потім просто на нього зсилався

                    усі конекти до бази в Qt є статичними


                    по приклату який ти скинув важно щось сказати....





                      Ruslan Polupan
                      • Қар. 12, 2018, 1:42 Т.Ж.

                      Из опыта: Прежде чем использовать запрос в QSqlQuery напиши его и выполни непосредственно на базе данных. Убедись что он работает а потом переноси уже в программу. Сразу отпадет масса вопросов.


                        R
                        • Қар. 12, 2018, 2:50 Т.Ж.

                        тому що цей запит не коректний, в тебе там зайві коми, зайва крапка з комою

                        порівняй з от цим


                      • m_query.prepare("INSERT INTO name_table (id_item)"
                      • " VALUES (:id_item)");
                        • Михаиллл
                          • Қар. 12, 2018, 3 Т.Ж.

                          Большое спасибо всем за помощь.

                          Так работает

                          QSqlDatabase TestDB = QSqlDatabase::addDatabase("QSQLITE"); //resume sql
                                  TestDB.setDatabaseName("C:\\CVReader\\TestSQLite.db");
                                  if (!TestDB.open()) {qDebug()<<"not open";}
                                  QSqlQuery query;
                                  int q1 = 124;
                                  query.prepare("INSERT INTO TestSQL (TestInt)VALUES (:q1);");
                                  query.bindValue(":q1",q1);
                                  if (!query.exec()) {qDebug()<<"не записалось";}
                                  else {qDebug()<<"записалось";}

                                  TestDB.close();






                            p
                            • Қыр. 24, 2020, 4:58 Т.Ж.
                            • (өңделген)

                            Добрий день.
                            Я реалізую з'єдання з БД у окремому потоці.

                            dbName = "my_db_" + QString::number((quint64)QThread::currentThread(), 16);

                            db = QSqlDatabase::addDatabase("QSQLITE", dbName);
                            db.setPort(dataBase->port());
                            db.setHostName(dataBase->hostName());
                            db.setDatabaseName(dataBase->databaseName());
                            dbIsValid = db.open();

                            І БД відкривається. Проте при створення QSqlQuery:

                            QString resualtQuery {"SELECT rowId, * FROM Contacts WHERE Name = \"" + name + "\""};
                            QSqlQuery sqlQuery {resualtQuery};

                            Виникає помилка:

                            QSqlDatabasePrivate::database: requested database does not belong to the calling thread.
                            QSqlQuery::prepare: database not open

                            Робота з потоками організована на основі signal-slot в Qt::DirectConnection.
                            Підкажіть, будь-ласка, що може бути не так?

                              p
                              • Қыр. 24, 2020, 7:12 Т.Ж.
                              • (өңделген)

                              Вирішення знайшов.
                              Вказав замість назви БД об'єкт класу QSqlDataBase для QSqlQuery.

                              QSqlQuery m_query = QSqlQuery(qSqlDataBase);

                              Після двох днів пошуку рішення, все-таки знайшов.

                                Пікірлер

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

                                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 Добрый день. По моему мнению - да, но то, что будет касаться вызовов к функционалу Андроида, может создать огромные трудности.

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