MihailllNov. 10, 2018, 9:47 a.m.

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

Qt, SQLite

Добрый день.

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

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

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

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


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

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

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.
15
R
  • Nov. 10, 2018, 9:59 a.m.
  • The answer was marked as a solution.
    QSqlDatabase dbcache = QSqlDatabase::addDatabase("QSQLITE", "cache");
    dbcache.setDatabaseName("/dbc.db3");


    if (!dbcache.open()) {
        qDebug() << "error connect to database" << dbcache.lastError().text();
        return false;
    }

Спасибо.

И еще вопрос, пытаюсь использовать запрос 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

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

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();
    }

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

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

тут 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)");

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

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

    QSqlQuery query;
    query.prepare("INSERT INTO person (id, forename, surname) ""VALUES (:id, :forename, :surname)");
R

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

можно так

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

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


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

QSqlQuery query;



Сделал тренировочную таблицу. Если вот так писать, то при первом запросе нет ошибок, но при повторе действия выдает ошибку 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, данные не добавляются.

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

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


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

        query.exec();
R

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



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

QSqlDatabase::removeDatabase(name_connect);


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

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


........

QSqlDatabase::removeDatabase("connect_db");



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

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


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





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


R

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

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


  • m_query.prepare("INSERT INTO name_table (id_item)"
  • " VALUES (:id_item)");
  • Большое спасибо всем за помощь.

    Так работает

    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

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

    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

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

    QSqlQuery m_query = QSqlQuery(qSqlDataBase);

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

    Comments

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

    Let me recommend you the excellent hosting on which EVILEG is located.

    For many years, Timeweb has been proving his stability.

    For projects on Django I recommend VDS hosting

    View Hosting
    V
    • Vitreg
    • Oct. 26, 2020, 1:35 a.m.

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

    • Result:73points,
    • Rating points1
    V
    • Vitreg
    • Oct. 26, 2020, 1:23 a.m.

    C++ - Test 005. Structures and Classes

    • Result:83points,
    • Rating points4
    K
    • Kanes
    • Oct. 25, 2020, 8:42 a.m.

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

    • Result:60points,
    • Rating points-1
    Last comments
    S

    QML - Lesson 026. Intents with Qt for Android, part 1

    Есть ли возможность приведения java типа у QAndroidJniObject? Интересует конкретно class to
    VK

    Qt/C++ - Lesson 015. QTableWidget – How to create a table with checkboxes?

    Кто-нибудь знает, как сделать так, чтобы в QTableWidget состоящей из чекбоксов в строке таблицы можно было выбрать только один checkbox ?

    Qt/C++ - Lesson 006. QSqlQueryModel – Tables in Qt with SQL-query

    QSqlTableModel выполняет ряд стандартных операций для одной таблицы из базы данных. Поэтому там и реализован функционал по удалению и редактированию. QSqlQueryModel позволяет выполнить запр…
    VB

    Qt/C++ - Lesson 006. QSqlQueryModel – Tables in Qt with SQL-query

    Добрый день. Хотел спросить вот что. Создал проект на основе QAbstractTableModel. В MainWindow cоответственно создал модель и связал с представлением. Поиск веду по списку элементов модели,…

    QCheckBox в качестве делегата QTableView

    До тех пор, пока у вас проект содержит только одну таблицу, или несколько то может быть. Когда их будет 1000 и чекбоксы в разных колонках, то без делегатов и переопределения возвращаемых ре…
    Now discuss on the forum

    QSqlTableModel - Как добавить картинки в таблицу, чтобы они отражались в диалоговом окне, но не были частью модели

    Ну тогда в этом столбце указывайте пути на несколько картинок
    u
    • ubomj
    • Oct. 27, 2020, 9:34 a.m.

    Создание черновика как на авито и тд

    Ну пользователь я думаю не настроен будет жмакать кнопку создать черновик, потом продолжать заполнять... А черновик в свою очередь нужен пока только для получения id, который нужен для муль…

    QGraphicItems объекты

    спасибо
    • BlinCT
    • Oct. 24, 2020, 6:14 a.m.

    Открытие файла и чтение данных из него по средством башевского запроса

    И так же интересно как в случаи чтения из потока таким путем можно узнавать об окончании файла?
    KM

    Qt анимация диалога c++

    Хочу сдедать диалог который будет выпадать с помощью анимации Анимация готова но я не знаю как попровать ее так чтобы мой диалог выезжал с верху на центр, при закрытии диалог заезжает навер…
    About
    Services
    © EVILEG 2015-2020
    Recommend hosting TIMEWEB