Гость
Форумы / Oracle [игнор отключен] [закрыт для гостей] / Работа с датами / 5 сообщений из 5, страница 1 из 1
06.03.2019, 11:01
    #39782814
WhiteChapel
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Работа с датами
Помогите пожалуйста с запросом. Есть таблица clients в ней столбцы name, birth_date. Надо найти клиентов у которых день рождения в следующем месяце. Пробовал так, не работает:
SELECT name, birth_date
FROM clients
WHERE MONTH (birth_date) = MONTH (DATE_ADD (NOW(), INTERVAL 1 MONTH));
...
Рейтинг: 0 / 0
06.03.2019, 11:11
    #39782821
123йй
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Работа с датами
WhiteChapel,
Код: plsql
1.
2.
3.
4.
5.
6.
7.
8.
Connected to Oracle Database 12c Enterprise Edition Release 12.2.0.1.0 

SQL> select sysdate,trunc(sysdate,'mm'),trunc(add_months(sysdate,1),'mm')  from dual ;
SYSDATE     TRUNC(SYSDATE,'MM') TRUNC(ADD_MONTHS(SYSDATE,1),'M
----------- ------------------- ------------------------------
06.03.2019  01.03.2019          01.04.2019

SQL> 
...
Рейтинг: 0 / 0
06.03.2019, 11:25
    #39782830
Stax
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Работа с датами
WhiteChapel,

Код: plsql
1.
2.
3.
4.
5.
6.
  1* select * from emp where mod(extract(month from sysdate),12)+1=extract(month from hiredate)
SQL> /

     EMPNO ENAME      JOB              MGR HIREDATE        SAL       COMM     DEPTNO
---------- ---------- --------- ---------- -------- ---------- ---------- ----------
      7566 JONES      MANAGER         7839 02.04.81       2975                    20


....
stax
...
Рейтинг: 0 / 0
06.03.2019, 14:23
    #39783001
Oleg M.Ivanov
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Работа с датами
Что-то у топикстартера запрос больше на mysql смахивает. Наверно, веткой ошибся.
...
Рейтинг: 0 / 0
06.03.2019, 15:43
    #39783039
Oleg M.Ivanov
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Работа с датами
Поскольку, правая часть условия запроса ТС возвращает правильно 4, то я бы посоветовал выполнить такой селект и посмотреть, что будет возвращать MONTH (birth_date). Есть предположение, что birth_date в базе хранится не в виде даты, а в строке.
Код: plsql
1.
SELECT name, birth_date, MONTH (birth_date) FROM clients


...но это чисто предположение, т.к. mysql'ем уже очень давно не занимался и не помню, будет ли выдавать ошибку в таком случае или просто не работать как надо.
...
Рейтинг: 0 / 0
Форумы / Oracle [игнор отключен] [закрыт для гостей] / Работа с датами / 5 сообщений из 5, страница 1 из 1
Целевая тема:
Создать новую тему:
Автор:
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]