МихаилллNov. 10, 2018, 10:47 a.m.
через 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
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!
AD
- Akiv Doros
- Nov. 12, 2024, 3:58 a.m.
C ++ - Test 004. Pointers, Arrays and Loops
- Result:50points,
- Rating points-4
m
- molni99
- Oct. 26, 2024, 1:37 p.m.
C ++ - Test 004. Pointers, Arrays and Loops
- Result:80points,
- Rating points4
m
- molni99
- Oct. 26, 2024, 1:29 p.m.
C ++ - Test 004. Pointers, Arrays and Loops
- Result:20points,
- Rating points-10
Last comments
How to make game using Qt - Lesson 3. Interaction with other objects what is priligy tablets What happens during the LASIK surgery process
Using variables declared in CMakeLists.txt inside C ++ files where can i buy priligy online safely Tom Platz How about things like we read about in the magazines like roid rage and does that really
Django - Tutorial 055. How to write auto populate field functionality Freckles because of several brand names retin a, atralin buy generic priligy
QML - Tutorial 035. Using enumerations in QML without C ++ priligy cvs 24 Together with antibiotics such as amphotericin B 10, griseofulvin 11 and streptomycin 12, chloramphenicol 9 is in the World Health Organisation s List of Essential Medici…
Qt/C++ - Lesson 052. Customization Qt Audio player in the style of AIMP It decreases stress, supports hormone balance, and regulates and increases blood flow to the reproductive organs buy priligy online safe Promising data were reported in a PDX model re…
Now discuss on the forum
добавить qlineseries в функции Listen intently to what Jerry says about Conditional Acceptance because that s the bargaining chip in the song and dance you will have to engage in to protect yourself and your family from AMI S…
Всё ещё разбираюсь с кешем. 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
IscanderCheNov. 1, 2024, 3:43 a.m.
Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…
ИМ
Реализация навигации по разделам Спасибо Евгений!
Игорь МаксимовOct. 3, 2024, 4:05 p.m.
Спасибо.
И еще вопрос, пытаюсь использовать запрос exec, но выдает ошибку QSqlQuery::exec: database not open
код такой
прочитай хотя бы это
http://www.java2s.com/Code/Cpp/Qt/UsingsqldatabasefromQt.htm
спасибо , читаю.
но почему у меня не верно?
тут https://doc.qt.io/qt-5.11/qsqlquery.html#exec также написано.
их пример
и скажите пожалуйста, что такое cache
и по предложенной Вами ссылки также делают
cache это название соединения
можно так
тогда будет какая-то базовая название соединения
если я не ошибаюсь вот так будет работать твой вариант, так как при таком, ты не передаешь соединения для квери
Сделал тренировочную таблицу. Если вот так писать, то при первом запросе нет ошибок, но при повторе действия выдает ошибку QSqlDatabasePrivate::addDatabase: duplicate connection name 'qt_sql_default_connection', old connection removed.
Смотрел в редакторе SQL, данные не добавляются.
Подскажите пожалуйста, что не так.
и если делать так, тоже не работает
мені по російски важко писати тому, моежш перкласти ))))
помилка виникає тому що ти намагаєшся створити ще одне з'єднання з такоюж назвою, щоб це зробити спочатку потрібно видалити старе з'єднання
QSqlDatabase::removeDatabase(name_connect);
ти можеш зробити так
........
QSqlDatabase::removeDatabase("connect_db");
якщо у вас плануєтсяь виокористовувати одну базу то яб просто встановив зєднання десь на початку програми і потім просто на нього зсилався
усі конекти до бази в Qt є статичними
по приклату який ти скинув важно щось сказати....
Из опыта: Прежде чем использовать запрос в QSqlQuery напиши его и выполни непосредственно на базе данных. Убедись что он работает а потом переноси уже в программу. Сразу отпадет масса вопросов.
тому що цей запит не коректний, в тебе там зайві коми, зайва крапка з комою
порівняй з от цим
Большое спасибо всем за помощь.
Так работает
Добрий день.
Я реалізую з'єдання з БД у окремому потоці.
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.
Підкажіть, будь-ласка, що може бути не так?
Вирішення знайшов.
Вказав замість назви БД об'єкт класу QSqlDataBase для QSqlQuery.
QSqlQuery m_query = QSqlQuery(qSqlDataBase);
Після двох днів пошуку рішення, все-таки знайшов.