Russian Qt Forum
Ноябрь 22, 2024, 23:33
Добро пожаловать,
Гость
. Пожалуйста,
войдите
или
зарегистрируйтесь
.
Вам не пришло
письмо с кодом активации?
1 час
1 день
1 неделя
1 месяц
Навсегда
Войти
Начало
Форум
WIKI (Вики)
FAQ
Помощь
Поиск
Войти
Регистрация
Russian Qt Forum
>
Forum
>
Qt
>
Базы данных
>
Подключение QT к Access, операция INSERT
Страниц: [
1
]
Вниз
« предыдущая тема
следующая тема »
Печать
Автор
Тема: Подключение QT к Access, операция INSERT (Прочитано 5682 раз)
Praid
Гость
Подключение QT к Access, операция INSERT
«
:
Февраль 06, 2018, 10:54 »
Товарищи, такой вопрос.
Подключил QT к ACCESS. Таким вот образом:
QSqlDatabase db = QSqlDatabase::addDatabase("QODBC");
db.setHostName("127.0.0.1");
db.setDatabaseName("Driver={Microsoft Access Driver (*.mdb, *.accdb)}SN=''BQ=C:\\database.accdb");
db.setUserName("root");
if(!db.open())
qDebug() << db.lastError().text();
else
qDebug() << "Connect!";
К базе данных подключился, qDebug мне написал Connect, всё хорошо.
На форме в представлении view записи из БД сохранились.
Далее пытаюсь сделать вставку в БД. Таким образом:
QSqlQuery* query = new QSqlQuery(db);
query->prepare("INSERT INTO devices(type, number) VALUES (:type, :number);");
query->bindValue(":type", "someType");
query->bindValue(":number", 123);
query->exec();
qDebug() << query->lastError().databaseText();
qDebug() << query->lastError().driverText();
qDebug выдаёт следующее:
"[Microsoft][Драйвер ODBC Microsoft Access] Ошибка синтаксиса в инструкции INSERT INTO."
"QODBC3: Unable to prepare statement"
Я уже всякий способ перепробовал.
C использованием безымянных параметров:
QSqlQuery* query = new QSqlQuery(db);
query->prepare("INSERT INTO devices(type,number) VALUES (?, ?);");
query->bindValue(":type", "someType");
query->bindValue(":number", 123);
qDebug() << query->lastError().databaseText();
qDebug() << query->lastError().driverText();
Без подготовки:
query->exec("INSERT INTO devices(type, number) VALUES ('someType',157);");
Одна и та же ошибка:
"[Microsoft][Драйвер ODBC Microsoft Access] Ошибка синтаксиса в инструкции INSERT INTO."
"QODBC3: Unable to prepare statement"
Кто может подсказать где проблема в синтаксисе?
При использовании такого запроса:
QSqlQuery query;
query.prepare("INSERT INTO devices(type,number) VALUES (?, ?);");
query.bindValue(":type","someType");
query.bindValue(":number","123");
query.exec();
qDebug() << query.lastError();
Ошибка:
QODBCResult::exec: Unable to execute statement: "[Microsoft][Драйвер ODBC Microsoft Access]Неверное поле COUNT "
QSqlError("17", "QODBC3: Unable to execute statement", "[Microsoft][Драйвер ODBC Microsoft Access]Неверное поле COUNT ")
А что за поле COUNT, если у меня в таблице только два столбца - type, number?
Записан
qate
Супер
Offline
Сообщений: 1177
Re: Подключение QT к Access, операция INSERT
«
Ответ #1 :
Февраль 06, 2018, 12:08 »
https://stackoverflow.com/questions/23449776/odbc-microsoft-access-drivercount-field-incorrect
Записан
Praid
Гость
Re: Подключение QT к Access, операция INSERT
«
Ответ #2 :
Февраль 06, 2018, 13:55 »
Всё. Проблема решена. Всё дело в скобках [].
QSqlQuery query;
if(query.prepare("INSERT INTO [devices] ([type],[number]) VALUES (:type, :number)"))
{
query.bindValue(":type","someType");
query.bindValue(":number","124");
qDebug() << query.exec();
}
qDebug() << query.lastError();
Записан
Страниц: [
1
]
Вверх
Печать
« предыдущая тема
следующая тема »
Перейти в:
Пожалуйста, выберите назначение:
-----------------------------
Qt
-----------------------------
=> Вопросы новичков
=> Уроки и статьи
=> Установка, сборка, отладка, тестирование
=> Общие вопросы
=> Пользовательский интерфейс (GUI)
=> Qt Quick
=> Model-View (MV)
=> Базы данных
=> Работа с сетью
=> Многопоточное программирование, процессы
=> Мультимедиа
=> 2D и 3D графика
=> OpenGL
=> Печать
=> Интернационализация, локализация
=> QSS
=> XML
=> Qt Script, QtWebKit
=> ActiveX
=> Qt Embedded
=> Дополнительные компоненты
=> Кладовая готовых решений
=> Вклад сообщества в Qt
=> Qt-инструментарий
-----------------------------
Программирование
-----------------------------
=> Общий
=> С/C++
=> Python
=> Алгоритмы
=> Базы данных
=> Разработка игр
-----------------------------
Компиляторы и платформы
-----------------------------
=> Linux
=> Windows
=> Mac OS X
=> Компиляторы
===> Visual C++
-----------------------------
Разное
-----------------------------
=> Новости
===> Новости Qt сообщества
===> Новости IT сферы
=> Говорилка
=> Юмор
=> Объявления
Загружается...