Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > Базы данных
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 20.01.2012, 20:07
Stalker999 Stalker999 вне форума
Прохожий
 
Регистрация: 28.10.2011
Сообщения: 36
Репутация: 10
По умолчанию Sql запросы

Доброго времени суток, помогите разобраться.
Не работает запрос:
Код:
 Form1.query1.SQL.Text:='Select Колличество, Название_покупателя,Название_товара,Категория_Товара,Цена  from Товар, ПриходТовара where Код_товара=КодТовара';
А если убрать "Колличество" то работает.
Ошибка такая:
Invalid use of keyword
Token: чество,

Последний раз редактировалось lmikle, 20.01.2012 в 21:24.
Ответить с цитированием
  #2  
Старый 20.01.2012, 21:26
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,015
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Либо у тебя там в слове пробел затесался, либо проблема с русскими именами полей. Если это MS SQL или Access, то имена полей заключи в кв. скобки, если другая БД - попробуй двойные кавычки. А на будущее - не используй русские названия полей - пиши латиницей и проблем не будет.
Ответить с цитированием
Этот пользователь сказал Спасибо lmikle за это полезное сообщение:
Stalker999 (20.01.2012)
  #3  
Старый 20.01.2012, 21:44
Stalker999 Stalker999 вне форума
Прохожий
 
Регистрация: 28.10.2011
Сообщения: 36
Репутация: 10
По умолчанию

Спасибо, попробую латиницей. А базу делаю в database desctop
Ответить с цитированием
  #4  
Старый 20.01.2012, 21:48
Stalker999 Stalker999 вне форума
Прохожий
 
Регистрация: 28.10.2011
Сообщения: 36
Репутация: 10
По умолчанию

Латиницей написал и всё работает, а другие поля ведь по-русски и работают. Ещё раз спасибо за совет)
Ответить с цитированием
  #5  
Старый 20.01.2012, 22:25
Stalker999 Stalker999 вне форума
Прохожий
 
Регистрация: 28.10.2011
Сообщения: 36
Репутация: 10
По умолчанию

Снова я. Что не так здесь? При вводе названия в edit получается ошибка Invalid field name...
PHP код:
Form1.query1.SQL.Text:='Select Kol, Название_покупателя,Название_товара,Категория_Товара,Цена  from Товар JOIN ПриходТовара ON   Код_товара=КодТовара and Название_Покупателя = '+form1.Edit1.Text
Ответить с цитированием
  #6  
Старый 21.01.2012, 18:47
Аватар для Sofia Guseva
Sofia Guseva Sofia Guseva вне форума
Прохожий
 
Регистрация: 24.12.2011
Адрес: Липецк
Сообщения: 11
Версия Delphi: 6.0
Репутация: 157
Смех

Цитата:
Сообщение от Stalker999
Снова я. Что не так здесь? При вводе названия в edit получается ошибка Invalid field name...
PHP код:
Form1.query1.SQL.Text:='Select Kol, Название_покупателя,Название_товара,Категория_Товара,Цена  from Товар JOIN ПриходТовара ON   Код_товара=КодТовара and Название_Покупателя = '+form1.Edit1.Text


Ошибка - Неправильное имя поля. Либо ты его неправильно написал либо оно вообще не существует.
Ответить с цитированием
  #7  
Старый 21.01.2012, 19:38
Stalker999 Stalker999 вне форума
Прохожий
 
Регистрация: 28.10.2011
Сообщения: 36
Репутация: 10
По умолчанию

Вот скрин, в табл есть поле NazvaniePokupatelja, ввожу например ООО в edit и ошибка...
Безымянный.JPG
Ответить с цитированием
  #8  
Старый 21.01.2012, 20:34
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,015
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Цитата:
Сообщение от Stalker999
Вот скрин, в табл есть поле NazvaniePokupatelja, ввожу например ООО в edit и ошибка...

Если так дбавлять значение из Edit1, то база понимает его как имя поля. Ты же, как я понимаю, хочешь отфильтровать записи по некоторому значению. Текстовое значение должно идти в запросе в кавычках. Соответсвенно, это должно выглядеть примерно так (использую функцию format для упрощения):
Код:
Form1.query1.SQL.Text:=Format('Select Kol, Название_покупателя,Название_товара,Категория_Товара,Цена  from Товар JOIN ПриходТовара ON   Код_товара=КодТовара and Название_Покупателя = ''%s''',[form1.Edit1.Text]);

В коде ВЕЗДЕ стоят апострофы, НЕ двойные кавычки.
Ответить с цитированием
Этот пользователь сказал Спасибо lmikle за это полезное сообщение:
Stalker999 (21.01.2012)
  #9  
Старый 21.01.2012, 20:58
Stalker999 Stalker999 вне форума
Прохожий
 
Регистрация: 28.10.2011
Сообщения: 36
Репутация: 10
По умолчанию

Спасибо, теперь надо разобраться, в жизни пригодится)
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 09:41.


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2023

ВКонтакте   Facebook   Twitter