Форум программистов, компьютерный форум, киберфорум
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. Показов 1300. Ответов 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
33197 / 21493 / 8233
Регистрация: 22.10.2011
Сообщений: 36,882
Записей в блоге: 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
33197 / 21493 / 8233
Регистрация: 22.10.2011
Сообщений: 36,882
Записей в блоге: 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
9907 / 6444 / 2455
Регистрация: 21.01.2014
Сообщений: 27,353
Записей в блоге: 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
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru