crossplatform.ru

Здравствуйте, гость ( Вход | Регистрация )

 
Ответить в данную темуНачать новую тему
> биндинг полей в QSqlQuery, для sqlite
Andrewshkovskii
  опции профиля:
сообщение 8.12.2010, 18:48
Сообщение #1


Активный участник
***

Группа: Участник
Сообщений: 351
Регистрация: 27.12.2008
Пользователь №: 467

Спасибо сказали: 18 раз(а)




Репутация:   1  


Есть простая табличка parameter_source (id_unit, name, definition). Пытаюсь через QSqlQuery вставить данные в неё :
       query->prepare(qq.value(0));
       query->bindValue(":id_unit",QString("null"));
       query->bindValue(":name",QString("name"));
       query->bindValue(":definition",QString("definition"));
       query->exec();
       qDebug() << query->boundValues();
       qDebug() << query->executedQuery();
       qDebug() << query->lastError();

Исходный запрос
insert into PARAMETER_SOURCE (id_unit, name, definition) VALUES (:id_unit, :name, :definition);

И на выходе получаю :
Цитата
QMap((":definition", QVariant(QString, "definition") ) ( ":id_unit" , QVariant(QString, "null") ) ( ":name" , QVariant(QString, "name") ) )
"insert into PARAMETER_SOURCE (id_unit, name, definition) VALUES (?, ?, ?);"
QSqlError(-1, "Parameter count mismatch", "")

Пробовал все 4 способо биндинга значение, все приводит к одному результату.
Разве sqlite не поддерживает биндинги? Или я делаю что-то не так?

Сообщение отредактировал Andrewshkovskii - 8.12.2010, 18:49
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение
Litkevich Yuriy
  опции профиля:
сообщение 8.12.2010, 20:17
Сообщение #2


разработчик РЭА
*******

Группа: Сомодератор
Сообщений: 9669
Регистрация: 9.1.2008
Из: Тюмень
Пользователь №: 64

Спасибо сказали: 807 раз(а)




Репутация:   94  


Цитата(Andrewshkovskii @ 8.12.2010, 20:48) *
query->prepare(qq.value(0));
что возвращает qq.value(0)?
приведи само значение
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение
Andrewshkovskii
  опции профиля:
сообщение 8.12.2010, 20:18
Сообщение #3


Активный участник
***

Группа: Участник
Сообщений: 351
Регистрация: 27.12.2008
Пользователь №: 467

Спасибо сказали: 18 раз(а)




Репутация:   1  


"insert into PARAMETER_SOURCE (id_unit, name, definition) VALUES (:id_unit, :name, :definition);"

Т.е. точно так же, как и написан запрос в внешнем файле.
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение
Litkevich Yuriy
  опции профиля:
сообщение 8.12.2010, 20:37
Сообщение #4


разработчик РЭА
*******

Группа: Сомодератор
Сообщений: 9669
Регистрация: 9.1.2008
Из: Тюмень
Пользователь №: 64

Спасибо сказали: 807 раз(а)




Репутация:   94  


Цитата(Andrewshkovskii @ 8.12.2010, 20:48) *
Разве sqlite не поддерживает биндинги?
это не важно, если СУБД их не поддерживает, драйвер Qt будет сам их имитировать

не соображу почему он так ругается.

Если я правильно понимаю, что там за таблица, т.е. первое поле - числовое. То ругаться должен на
QString("null")

т.е. не соответствие типов
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение
Andrewshkovskii
  опции профиля:
сообщение 8.12.2010, 23:12
Сообщение #5


Активный участник
***

Группа: Участник
Сообщений: 351
Регистрация: 27.12.2008
Пользователь №: 467

Спасибо сказали: 18 раз(а)




Репутация:   1  


Вообще да, запрос логически не верен, первой поле числовое (это первичный ключ), с автоинкриментом.
Но дело в том, что такой запрос sqlite отрабатывает нормально, без ошибок
insert into parameter_source values (null, 'aa','aaaa');


Видать qtшный драйвер шалит?
Попробовал сделать вот так вот :
       query->prepare(qq.value(0));
       query->bindValue(0,10);
       query->bindValue(1,QString("name"));
       query->bindValue(2,QString("definition"));
       query->exec();
       qDebug() << qq.value(0);
       qDebug() << query->boundValues();
       qDebug() << query->executedQuery();
       qDebug() << query->lastError();

А результат все тот же
"insert into PARAMETER_SOURCE (id_unit, name, definition) VALUES (:id_unit, :name, :definition);" 
QMap((":definition", QVariant(QString, "definition") ) ( ":f" ,  QVariant(int, 10) ) ( ":name" ,  QVariant(QString, "name") ) )  
"insert into PARAMETER_SOURCE (id_unit, name, definition) VALUES (?, ?, ?);"
QSqlError(-1, "Parameter count mismatch", "")


Видать придется QString.arg использовать..
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение
Andrewshkovskii
  опции профиля:
сообщение 9.12.2010, 2:09
Сообщение #6


Активный участник
***

Группа: Участник
Сообщений: 351
Регистрация: 27.12.2008
Пользователь №: 467

Спасибо сказали: 18 раз(а)




Репутация:   1  


Бред какой-то.
Вот теперь запрос выглядит так :
insert into PARAMETER_SOURCE VALUES(%1,'%2','%3');

В коде :
       query->prepare(qq.value(0).arg("1").arg("blahblah").arg("BLAAA"));
       query->exec();
       qDebug() << qq.value(0);
       qDebug() << query->executedQuery();
       qDebug() << query->lastError();

Результат :
"insert into PARAMETER_SOURCE VALUES(%1,'%2','%3');" 
"insert into PARAMETER_SOURCE VALUES(1,'blahblah','BLAAA');"
QSqlError(-1, "Unable to fetch row", "No query")

Вот теперь точно ничего не понимаю. такой же запрос отрабатывается через админку для sqlite, а из кода не хочет. Не понимать. База 100% открывается, очередь к базе подключается...
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение
Гость_Гость_*
сообщение 21.5.2013, 8:53
Сообщение #7





Гости








    


QSqlQuery *pQuery = new QSqlQuery(...);
pQuery->prepare(
               "INSERT INTO table(id, text) "
               "VALUES (:id, :text);"
               );
pQuery->bindValue(":id", 123);
pQuery->bindValue(":text", "text");
pQuery->exec();


Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение
lanz
  опции профиля:
сообщение 21.5.2013, 11:29
Сообщение #8


Старейший участник
****

Группа: Участник
Сообщений: 690
Регистрация: 28.12.2012
Пользователь №: 3660

Спасибо сказали: 113 раз(а)




Репутация:   8  


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

EDIT: ой вей, прошу прощения за гробокопательство, не посмотрел дату.

Сообщение отредактировал lanz - 21.5.2013, 11:34
Прикрепленные файлы
Прикрепленный файл  scratch3.zip ( 1,97 килобайт ) Кол-во скачиваний: 292
 
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение

Быстрый ответОтветить в данную темуНачать новую тему
Теги
Нет тегов для показа


1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0




RSS Текстовая версия Сейчас: 22.11.2024, 0:43