Форум программистов, компьютерный форум, киберфорум
C++ Builder: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.83/6: Рейтинг темы: голосов - 6, средняя оценка - 4.83
0 / 0 / 0
Регистрация: 04.11.2012
Сообщений: 13

Ошибка "Invalid use of keyword" в SQL-запросе

27.04.2014, 17:26. Показов 1316. Ответов 11
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
собственно сама ошибка



а вот код обработчика кнопки
C++
1
2
3
4
5
6
7
8
void __fastcall TForm1::ButtonOutClick(TObject *Sender)
{
  char buf[200];
  sprintf(buf,"UPDATE table1 SET KOL=%i WHERE NK=%s CVET=%s",LabeledEdit5->Text.c_str(),LabeledEdit4->Text.c_str(),ComboBox2->Text.c_str());
  Query1->Close();
  Query1->SQL->Text=buf;
  Query1->Open();
}
Помогите слепцу прозреть
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
27.04.2014, 17:26
Ответы с готовыми решениями:

Парметрический запрос SQL (invalid use of keyword)
Подскажите в чем ошибка? DM.Q.Close; DM.Q.SQL.Clear; DM.Q.SQL.Add('Select *'); DM.Q.SQL.Add('From...

Ошибка invalid use of keyword
Доброго времени суток! Работаю над БД в Делфи. Использую компоненты Query и в качестве СУБД у меня стандартный DataBase Desktop/ так вот...

Ошибка: Invalid use of keyword
Invalid use of keyword. token 2.db where line number:2; В чем ошибка подскажите пожалуйста. Запрос верный. Пробовал по разному...

11
164 / 49 / 27
Регистрация: 04.06.2013
Сообщений: 636
27.04.2014, 21:52
что записано в buf?
0
 Аватар для Sasha
4956 / 2420 / 531
Регистрация: 05.06.2008
Сообщений: 7,518
Записей в блоге: 3
27.04.2014, 22:56
Цитата Сообщение от lsd180 Посмотреть сообщение
Помогите слепцу прозреть
А нельзя на прямую написать запрос без посреднических переменных
1
0 / 0 / 0
Регистрация: 04.11.2012
Сообщений: 13
28.04.2014, 00:05  [ТС]
Добавлено через 23 секунды
Цитата Сообщение от mish_k98 Посмотреть сообщение
что записано в buf?
в коде же все видно. изначально в ней ничего нет
0
Супер-модератор
Эксперт Pascal/DelphiАвтор FAQ
 Аватар для volvo
33398 / 21508 / 8236
Регистрация: 22.10.2011
Сообщений: 36,906
Записей в блоге: 12
28.04.2014, 01:17
Может, все-таки объединить условия выбора, например AND-ом, и привести типы в порядок? Как-то вот так:
C++
1
2
sprintf(buf, "UPDATE table1 SET KOL=%i WHERE NK=%s AND CVET=%s",
    LabeledEdit5->Text.ToInt(), LabeledEdit4->Text.c_str(), ComboBox2->Text.c_str());
Возможно, еще потребуются скобки и/или кавычки...
0
0 / 0 / 0
Регистрация: 04.11.2012
Сообщений: 13
29.04.2014, 12:19  [ТС]
теперь вот такая ошибка
Миниатюры
Ошибка "Invalid use of keyword" в SQL-запросе  
0
 Аватар для Oxotnuk
78 / 78 / 6
Регистрация: 18.06.2009
Сообщений: 533
29.04.2014, 12:25
а почему не "Голубой"? у нас так называют тех,кто имена полей/таблиц Кириллицей пишет....
Не в обиду,просто попробуй назвать поле желтый- yellow
0
Супер-модератор
Эксперт Pascal/DelphiАвтор FAQ
 Аватар для volvo
33398 / 21508 / 8236
Регистрация: 22.10.2011
Сообщений: 36,906
Записей в блоге: 12
29.04.2014, 12:27
lsd180, ты бы хоть написал, что за СУБД, и как выглядит вообще таблица, с которой работаешь...
0
0 / 0 / 0
Регистрация: 04.11.2012
Сообщений: 13
29.04.2014, 13:23  [ТС]
Цитата Сообщение от Oxotnuk Посмотреть сообщение
а почему не "Голубой"? у нас так называют тех,кто имена полей/таблиц Кириллицей пишет....
Не в обиду,просто попробуй назвать поле желтый- yellow
шутник смотрю, есть тематические паблики для вас вроде мдк. желтый это не имя поля, это содержимое. поле называется CVET, если ты не понял кода.
вот таблица
Миниатюры
Ошибка "Invalid use of keyword" в SQL-запросе  
0
Модератор
 Аватар для D1973
9921 / 6457 / 2457
Регистрация: 21.01.2014
Сообщений: 27,406
Записей в блоге: 3
03.05.2014, 23:18
Если мне склероз не изменяет, текстовые данные в запросе надо взять в апострофы, т.е типа того получится
C++
1
"UPDATE table1 SET KOL=%i WHERE NK='%s' AND CVET='%s'"
0
1408 / 572 / 127
Регистрация: 31.10.2011
Сообщений: 1,960
04.05.2014, 02:15
Цитата Сообщение от Oxotnuk Посмотреть сообщение
у нас так называют тех,кто имена полей/таблиц Кириллицей пишет
иногда даже с пробелами, а потом думают, а че SQL запрос не исполняется.
Я смотрю мода такая теперь пошла, особенно у тех, кто в аксесе БД делает.
Неужели нельзя хотя б транслитерацией записать, а в идеале толково перевести на английский

Добавлено через 28 минут
по теме, вот Саша в 3 посте дал хороший совет, но чет никто не прислушался. Зачем здесь надо sprintf?
C++
1
2
3
Query1->Close();
Query1->SQL->Text="UPDATE table1 SET KOL="+LabeledEdit5->Text+" WHERE NK='"+LabeledEdit4->Text+"' AND CVET='"+ComboBox2->Text+"'";
Query1->Open();
0
0 / 0 / 0
Регистрация: 04.11.2012
Сообщений: 13
04.05.2014, 16:35  [ТС]
проблема решена, всем спасибо. вместо Open() надо было использовать ExecSQL()
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
04.05.2014, 16:35
Помогаю со студенческими работами здесь

Ошибка: Invalid use of keyword
Invalid use of keyword. token FROM line number:1; В чем ошибка подскажите пожалуйста, Начинающий в БД

И снова ошибка 10770 invalid use of keyword
Добрый день, пытаюсь создать запрос, который высчитывает данные и сохраняет результат в таблицу вот запрос insert into JurLocalSumm...

Ошибка - Function Keyword is invalid here. This might cause later messages about end
Матлаб ругается на первую строчку - "Function Keyword is invalid here. This might cause later messages about end." function =...

Ошибка TypeError: 'dilimiter' is an invalid keyword argument for this function
Никак не могу разобраться в чем проблема ? import requests from bs4 import BeautifulSoup import csv URL =...

UPDATE ошибка Invalid use of keyword. Token: By Line Number: 2
В общем при двойном клике по DBGrid открывается форма на которой расположены 4 Edit'а в которых выводятся значения полей и на компоненте...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
12
Ответ Создать тему
Новые блоги и статьи
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru