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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 01.09.2011, 21:37
Velross Velross вне форума
Прохожий
 
Регистрация: 04.12.2009
Сообщения: 7
Репутация: 12
По умолчанию SQL. Как в таблице подсчитать количество записей с определенным годом?

Есть таблица в 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;
Пишет: "Dynamic SQL Error SQL error code=-104. Token unknown - line 1, column 24,' "

3. Подсчитать кол-во: ?

Подскажите, как надо правильно?
Ответить с цитированием
  #2  
Старый 02.09.2011, 06:33
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,093
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Угу, правильно говорит.
Код:
select count(*) from table where EXTRACT(YEAR FROM DATE_BIRTH) = :year
Соотв. в параметр year запихиваешь нужное значение и радуешься жизни.
Ответить с цитированием
  #3  
Старый 02.09.2011, 10:29
Velross Velross вне форума
Прохожий
 
Регистрация: 04.12.2009
Сообщения: 7
Репутация: 12
По умолчанию

Цитата:
Сообщение от lmikle
Соотв. в параметр year запихиваешь нужное значение и радуешься жизни.

Огромное Вам спасибо. Всё работает как надо, только вот с параметрами я работать не умею, поэтому сделал так:
Код:
dmBase.IBQueryUsers.SQL.Add('select count(*) from users where EXTRACT(YEAR FROM DATE_BIRTH) ='+IntToStr((Variant(CurrentYear)-18))+'');
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

Соглашения

Прочее

 

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