![]() |
|
|
|||||||
| Регистрация | << Правила форума >> | FAQ | Пользователи | Календарь | Поиск | Сообщения за сегодня | Все разделы прочитаны |
![]() |
|
|
Опции темы | Поиск в этой теме | Опции просмотра |
|
#1
|
|||
|
|||
|
Есть таблица в Firebird 2.5, в котором есть поле DATE_BIRTH, где храниться дата рождения в формате ДД.ММ.ГГГГ.
Необходимо подсчитать, сколько человек имеют, например возраст в 18 лет. Искал в Интернете, но толком ничего не получается. Алгоритм такой: 1. Получить год рождения для 18-лет от текущего года: Variant(CurrentYear)-18); 2. Сделать запрос Например такой запрос не работает: Код:
dmBase.IBQueryUsers.Active:=false;
dmBase.IBQueryUsers.SQL.Clear;
dmBase.IBQueryUsers.SQL.Add('Select count(DATE_BIRTH, EXTRACT(YEAR FROM DATE_BIRTH) AS YYYY ) from users');
dmBase.IBQueryUsers.Active:=true;3. Подсчитать кол-во: ? Подскажите, как надо правильно? |
|
#2
|
|||
|
|||
|
Угу, правильно говорит.
Код:
select count(*) from table where EXTRACT(YEAR FROM DATE_BIRTH) = :year |
|
#3
|
|||
|
|||
|
Цитата:
Огромное Вам спасибо. Всё работает как надо, только вот с параметрами я работать не умею, поэтому сделал так: Код:
dmBase.IBQueryUsers.SQL.Add('select count(*) from users where EXTRACT(YEAR FROM DATE_BIRTH) ='+IntToStr((Variant(CurrentYear)-18))+''); |