Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2003.07.07;
Скачать: CL | DM;

Вниз

Мастера! Помогите с запросом!!!   Найти похожие ветки 

 
Солер ©   (2003-06-13 08:40) [0]

Уважаемые, Мастера!
Начинающий запарился.

Помогите составить запрос.

В базе, в таблице которой есть столбец записываются данные в
формате DATE т.е. 12.12.1999 ну и так далее.
Как мне составить запрос,чтобы данные отбирались
игнорируя число и месяц, только по году.
Да ещё необходимый год для отбора данных обязательно вводится
в Edit.Text.

Спасибо


 
Соловьев ©   (2003-06-13 09:35) [1]

в Query.SQL пишем:
select *
from table1
where EXTRACT(YEAR FROM fielddate)=:P_Year

В проге пишем:
...
with Query do
begin
if Active then Close;
ParamByName("P_Year").AsDateTime := StrToDate(Edit1.Text);
//вместо Edit1.Text лучше использовать DateTimePicker
if Prepared then Prepare;
Open;
end;
...



 
Соловьев ©   (2003-06-13 09:39) [2]


> where EXTRACT(YEAR FROM fielddate)=:P_Year

...
where EXTRACT(YEAR FROM fielddate)=EXTRACT(YEAR FROM :P_Year)
...

наверное надо так :))


 
HSolo ©   (2003-06-13 09:45) [3]

Выборка по году:
select ... from ...
where extract(year from СтолбецСДатой) = НужныйГод
А какая разница, куда год вводится? Есть проблемы со вводом?


 
HSolo ©   (2003-06-13 10:22) [4]

опередил однофамилец :)) Ладно, еще 5 коп. Можно, конечно, и дату выбирать, но... зачем целая дата, если нужен только год? Может, проще вводить год чем-то вроде SpinEdit?


 
Солер ©   (2003-06-13 10:23) [5]

=> Соловьёву
Попробовал. Не идёт
Ввожу в Edit 2000(чтобы отобрать записи по 2000 году) пишет 2000 не является датой.

=> HSolo
Для моей программы удобнее если в Edit вводится значение года - 1999, 2000 и т.д.


 
Соловьев ©   (2003-06-13 10:25) [6]


> Ввожу в Edit 2000(чтобы отобрать записи по 2000 году) пишет
> 2000 не является датой.

конечно не является, тогда тебе надо StrToInt(Edit1.Text) и использовать первую конструкцию SQL.


 
Солер ©   (2003-06-13 10:51) [7]

Теперь гад выдаёт
mismstch in expression
что - то про несоответствие типов :(


 
Соловьев ©   (2003-06-13 11:08) [8]


> ParamByName("P_Year").AsDateTime := StrToDate(Edit1.Text);

...
ParamByName("P_Year").AsInteger := StrToInt(Edit1.Text);
...





 
Солер ©   (2003-06-13 11:41) [9]

Спасибо. Особено господину Соловьёву за терпение и выдержку с нами начинающими.
Ещё раз спасибо всё заработало


 
Соловьев ©   (2003-06-13 11:44) [10]


> за терпение и выдержку с нами начинающими.

я тоже начинающий, так что учусь вместе с Вами :)))



Страницы: 1 вся ветка

Текущий архив: 2003.07.07;
Скачать: CL | DM;

Наверх




Память: 0.49 MB
Время: 0.011 c
1-20094
ss300
2003-06-23 09:43
2003.07.07
считывание математических формул с Excel


1-20047
Aleksandr
2003-06-25 12:52
2003.07.07
Как присваивать PChar у нетипизированные значения?


11-20021
Alexander
2002-10-22 11:29
2003.07.07
Обработка сообщений.


1-20161
Gover
2003-06-25 11:54
2003.07.07
Множество


1-20159
vsu
2003-06-25 11:37
2003.07.07
Как застаить работать backspace?