![]() |
|
|
Регистрация | << Правила форума >> | 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))+''); |