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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 05.08.2009, 13:43
VINCE_NT VINCE_NT вне форума
Прохожий
 
Регистрация: 22.07.2009
Сообщения: 6
Репутация: 10
По умолчанию Сложность с Запросом

Ребята помогите с запросом пожалуста

Есть таблица по ней необходимо выбрать данные по колонке 'kat' где 'kat'=переменной "a" причем колонка 'data' >= переменной "b" и 'data' <= переменной "c" отсортировать по дате.

вот что получилось, как сюда прикрутить сравнений с переменной "c"?
Код:
query1.Close;
query1.SQL.clear;
query1.SQL.Add('select data,kat,summ from ":bux:intt.db" where  (kat = '''+a+''') and (data >= ('''+datetostr(b)+''')) order by data');
query1.Open;
dataSource1.dataset:=query1;

Последний раз редактировалось Admin, 05.08.2009 в 13:48.
Ответить с цитированием
  #2  
Старый 05.08.2009, 13:54
Grunch Grunch вне форума
Новичок
 
Регистрация: 08.04.2008
Адрес: Краснодар
Сообщения: 52
Репутация: 10
По умолчанию

Код:
SELECT data,kat,summ
FROM ":bux:intt.db"
WHERE (kat = a)
        AND (data>=DateToStr(b))
        AND (data<=DateToStr(c))
или
Код:
SELECT data,kat,summ
FROM ":bux:intt.db"
WHERE (kat = a)
        AND (data between DateToStr(b) and DateToStr(c))
Ответить с цитированием
  #3  
Старый 05.08.2009, 14:09
VINCE_NT VINCE_NT вне форума
Прохожий
 
Регистрация: 22.07.2009
Сообщения: 6
Репутация: 10
По умолчанию

Цитата:
Сообщение от Grunch
Код:
SELECT data,kat,summ
FROM ":bux:intt.db"
WHERE (kat = a)
        AND (data>=DateToStr(b))
        AND (data<=DateToStr(c))
или
Код:
SELECT data,kat,summ
FROM ":bux:intt.db"
WHERE (kat = a)
        AND (data between DateToStr(b) and DateToStr(c))



Ни так ни так не работает правильно, игнорирует вторую часть сравнения
Ответить с цитированием
  #4  
Старый 05.08.2009, 15:15
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,020
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Делай параметризиарованный запрос:

Код:
SELECT * FROM ":bux:intt.db"
WHERE kat = :A AND data >= :B AND data <= :C
ORDER BY data
...
Query1.Active := False;
Query1.ParamByName('A').AsString := a;
Query1.ParamByName('B').AsDateTime := b;
Query1.ParamByName('C').AsDateTime := c;
Query1.Active := True;
Ответить с цитированием
  #5  
Старый 05.08.2009, 15:28
VINCE_NT VINCE_NT вне форума
Прохожий
 
Регистрация: 22.07.2009
Сообщения: 6
Репутация: 10
По умолчанию

спасибо все работает, косяк в коде был а так все правильно сказали.
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

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

ВКонтакте   Facebook   Twitter