Форум программистов, компьютерный форум, киберфорум
Microsoft SQL Server
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.92/263: Рейтинг темы: голосов - 263, средняя оценка - 4.92
 Аватар для ember74
9 / 8 / 2
Регистрация: 07.10.2015
Сообщений: 510

Как определить первый и последний день текущего месяца?

09.10.2017, 13:09. Показов 52177. Ответов 22

Студворк — интернет-сервис помощи студентам
Подскажите пожалуйста, как определить первый и последний день текущего месяца?

SQL
1
2
3
4
5
6
7
8
DECLARE
@startdate datetime = ? 
@enddate datetime = ?
 
SELECT t1._Fld7641 AS 'Дата/Время', t1._Fld7643 AS 'Ср.время', t2._Description AS 'Описание', t1._Fld7647 AS 'ФИО'
FROM dbo._InfoRg7639 AS t1 
INNER JOIN dbo._Reference5145 AS t2
ON t1._Fld7640RRef = t2._IDRRef WHERE t1._Fld7641 BETWEEN @startdate AND @enddate
Что нужно подставить вместо вопросов?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
09.10.2017, 13:09
Ответы с готовыми решениями:

Определить последний день текущего месяца
Есть задание : Определить, сколько часов и минут осталось до конца текущего месяца. Вот что я сделал, но как задать последний день...

Как найти последний день текущего месяца?
Здравствуйте! Есть кнопка, при нажатии на которую в полях дат должны устанавливаться первое и последнее числе текущего месяца. ...

Последний день текущего месяца
Доброго времени суток форумчане. Подскажите каким образом можно узнать методами vba, является ли последний день текущего месяца субботой...

22
3614 / 2135 / 756
Регистрация: 02.06.2013
Сообщений: 5,169
09.10.2017, 13:38
T-SQL
1
2
3
4
5
6
7
8
9
10
11
declare @startdate date, @enddate date;
 
select
 @startdate = dateadd(day, -day(getdate()) + 1, cast(getdate() as date)),
 @enddate = dateadd(day, -1, dateadd(month, 1, @startdate));
 
-- Для 2012+
--select
-- @enddate = eomonth(@startdate);
 
select @startdate, @enddate, eomonth(@startdate);
1
 Аватар для ember74
9 / 8 / 2
Регистрация: 07.10.2015
Сообщений: 510
09.10.2017, 13:50  [ТС]
invm, Благодарю! уже сам догадался) теперь проблема в том, что условие where скорее всего не выполняется - данные не выводит. Предполагаю, что дело в форматах t1._Fld7641 AS 'Дата/Время' (datetime), а @startdate и @enddate (date). Не подскажите как из t1._Fld7641 AS 'Дата/Время' только дату оставить?)
0
3614 / 2135 / 756
Регистрация: 02.06.2013
Сообщений: 5,169
09.10.2017, 14:01
Цитата Сообщение от ember74 Посмотреть сообщение
Предполагаю, что дело в форматах t1._Fld7641 AS 'Дата/Время' (datetime), а @startdate и @enddate (date)
Не в этом. В предикате date неявно преобразуется к datetime.
0
 Аватар для ember74
9 / 8 / 2
Регистрация: 07.10.2015
Сообщений: 510
09.10.2017, 14:10  [ТС]
invm, Я вот так сделал

T-SQL
1
2
3
4
5
6
declare
@startdate date, 
@enddate date
 
SET @startdate = dateadd(month,datediff(month,0,GetDate()),0);
SET @enddate =  dateadd(day, -1, dateadd(month,1, @startdate));
А как явно преобразовать?))

Добавлено через 6 минут
если вместо

T-SQL
1
2
3
declare
@startdate date, 
@enddate date
написать

T-SQL
1
2
3
declare
@startdate datetime, 
@enddate datetime
данные все равно не выводятся
0
1116 / 761 / 183
Регистрация: 27.11.2009
Сообщений: 2,272
09.10.2017, 15:02
T-SQL
1
2
3
4
5
SELECT t1._Fld7641 AS [Дата/Время], t1._Fld7643 AS [Ср.время], t2._Description AS [Описание], t1._Fld7647 AS [ФИО]
FROM dbo._InfoRg7639 AS t1
JOIN dbo._Reference5145 AS t2 ON t1._Fld7640RRef = t2._IDRRef
WHERE t1._Fld7641>=DATEADD(MONTH,  DATEDIFF(MONTH,0,CURRENT_TIMESTAMP),0)
  AND t1._Fld7641< DATEADD(MONTH,1+DATEDIFF(MONTH,0,CURRENT_TIMESTAMP),0);
0
 Аватар для ember74
9 / 8 / 2
Регистрация: 07.10.2015
Сообщений: 510
09.10.2017, 15:05  [ТС]
iap, Спасибо, но запрос ничего не выводит(
0
1116 / 761 / 183
Регистрация: 27.11.2009
Сообщений: 2,272
09.10.2017, 15:09
Цитата Сообщение от ember74 Посмотреть сообщение
iap, Спасибо, но запрос ничего не выводит(
А совсем без WHERE что-нибудь выводит?
А есть ли t1._Fld7641, попадающее в текущий месяц вообще?

Какого типа поле t1._Fld7641?
0
 Аватар для ember74
9 / 8 / 2
Регистрация: 07.10.2015
Сообщений: 510
09.10.2017, 15:10  [ТС]
iap, Конечно выводит, и данные на текущий месяц есть
0
1116 / 761 / 183
Регистрация: 27.11.2009
Сообщений: 2,272
09.10.2017, 15:14
Цитата Сообщение от ember74 Посмотреть сообщение
iap, Конечно выводит, и данные на текущий месяц есть
Данные текущего месяца в таблице или уже в JOINе?
То есть, я предполагаю, что условие ON JOINа не выполняется для строк с датой текущего месяца.
0
 Аватар для ember74
9 / 8 / 2
Регистрация: 07.10.2015
Сообщений: 510
09.10.2017, 15:18  [ТС]
iap, Если выполнить этот запрос
T-SQL
1
2
3
SELECT t1._Fld7641 AS [Дата/Время], t1._Fld7643 AS [Ср.время], t2._Description AS [Описание], t1._Fld7647 AS [ФИО]
FROM dbo._InfoRg7639 AS t1
JOIN dbo._Reference5145 AS t2 ON t1._Fld7640RRef = t2._IDRRef
Выведутся данные из двух таблиц, и в колонке t1._Fld7641 AS [Дата/Время] будут данные от начала текущего месяца по сегодняшнее число
0
1116 / 761 / 183
Регистрация: 27.11.2009
Сообщений: 2,272
09.10.2017, 15:19
Цитата Сообщение от ember74 Посмотреть сообщение
iap, Если выполнить этот запрос
T-SQL
1
2
3
SELECT t1._Fld7641 AS [Дата/Время], t1._Fld7643 AS [Ср.время], t2._Description AS [Описание], t1._Fld7647 AS [ФИО]
FROM dbo._InfoRg7639 AS t1
JOIN dbo._Reference5145 AS t2 ON t1._Fld7640RRef = t2._IDRRef
Выведутся данные из двух таблиц, и в колонке t1._Fld7641 AS [Дата/Время] будут данные от начала текущего месяца по сегодняшнее число
И это поле точно имеет тип DATETIME?

Тогда это просто чудо.

А весь ли запрос вы тут нам показали?
Или есть в нём что-то ещё?
Например, в WHERE
0
 Аватар для ember74
9 / 8 / 2
Регистрация: 07.10.2015
Сообщений: 510
09.10.2017, 15:28  [ТС]
iap, datetime2,

Да, конечно весь
Миниатюры
Как определить первый и последний день текущего месяца?  
0
1116 / 761 / 183
Регистрация: 27.11.2009
Сообщений: 2,272
09.10.2017, 19:47
Тогда это чудо, истинно вам говорю!

Последняя попытка:
T-SQL
1
2
3
4
5
SELECT t1._Fld7641 AS [Дата/Время], t1._Fld7643 AS [Ср.время], t2._Description AS [Описание], t1._Fld7647 AS [ФИО]
FROM dbo._InfoRg7639 AS t1
JOIN dbo._Reference5145 AS t2 ON t1._Fld7640RRef = t2._IDRRef
WHERE t1._Fld7641>=CAST(DATEADD(MONTH,  DATEDIFF(MONTH,0,CURRENT_TIMESTAMP),0) AS DATETIME2)
  AND t1._Fld7641< CAST(DATEADD(MONTH,1+DATEDIFF(MONTH,0,CURRENT_TIMESTAMP),0) AS DATETIME2);
0
 Аватар для ember74
9 / 8 / 2
Регистрация: 07.10.2015
Сообщений: 510
10.10.2017, 08:13  [ТС]
iap, Пусто...но вот, что я заметил. Если выполнить вот такой запрос

T-SQL
1
2
3
4
SELECT t1._Fld7641 AS [Дата/Время], t1._Fld7643 AS [Ср.время], t1._Fld7647 AS [ФИО]
FROM dbo._InfoRg7639 AS t1
WHERE t1._Fld7641>=CAST(DATEADD(MONTH,  DATEDIFF(MONTH,0,CURRENT_TIMESTAMP),0) AS DATETIME2)
  AND t1._Fld7641< CAST(DATEADD(MONTH,1+DATEDIFF(MONTH,0,CURRENT_TIMESTAMP),0) AS DATETIME2);
Тоже ничего не выводит, но это невозможно. Может дело все таки в условии?

Добавлено через 1 час 11 минут
iap, Хм...а может быть такое, что дело в отображении года? В поле t1._Fld7641 AS [Дата/Время] отображается как 4017, т.е. полностью дата 4017-10-06? Это база из 1С поэтому так
0
1116 / 761 / 183
Регистрация: 27.11.2009
Сообщений: 2,272
10.10.2017, 10:55
4017-10-06 - а почему вы уверены, что это не 10 июня?
0
 Аватар для ember74
9 / 8 / 2
Регистрация: 07.10.2015
Сообщений: 510
10.10.2017, 12:10  [ТС]
iap, ну потому что есть еще и 4017-09-25) 25 месяца нет еще пока)
0
3614 / 2135 / 756
Регистрация: 02.06.2013
Сообщений: 5,169
10.10.2017, 13:47
ember74, выполняете
T-SQL
1
2
3
4
5
set statistics xml on;
 
Ваш проблемный запрос
 
set statistics xml off;
Открываете получившийся план выполнения, ПКМ на любом свободном месте, Save Ecution Plan as. Получившийся файл выкладываете тут.
0
 Аватар для ember74
9 / 8 / 2
Регистрация: 07.10.2015
Сообщений: 510
10.10.2017, 14:27  [ТС]
invm,
T-SQL
1
2
3
4
5
6
7
8
9
set statistics xml on;
 
SELECT t1._Fld7641 AS [Дата/Время], t1._Fld7643 AS [Ср.время], t2._Description AS [Описание], t1._Fld7647 AS [ФИО]
FROM dbo._InfoRg7639 AS t1
JOIN dbo._Reference5145 AS t2 ON t1._Fld7640RRef = t2._IDRRef
WHERE t1._Fld7641>=CAST(DATEADD(MONTH,  DATEDIFF(MONTH,0,CURRENT_TIMESTAMP),0) AS DATETIME2)
  AND t1._Fld7641< CAST(DATEADD(MONTH,1+DATEDIFF(MONTH,0,CURRENT_TIMESTAMP),0) AS DATETIME2);
 
set statistics xml off;
загрузить не получилось, пишет "Некорректный файл" вот ссылка на яндекс.диск https://yadi.sk/d/fFBx1BNU3NdLqJ
0
3614 / 2135 / 756
Регистрация: 02.06.2013
Сообщений: 5,169
10.10.2017, 15:04
В общем, как и следовало ожидать, нет у вас там строк в dbo._InfoRg7639, удовлетворяющих предикату в where. Что не удивительно, если у вас в таблице 4000-е года.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
10.10.2017, 15:04
Помогаю со студенческими работами здесь

Как вывести первый и последний день предыдущего месяца?
как вывести первый и последний день предыдущего месяца?? (не зависимо количества дней в месяце)?????????????

Узнать первый день текущего месяца
Доброго временни суток, подскажите пожалуйста есть ли способ узнать какой был первый день месяца (день недели) и сколько в этом месяце дней?

Определите первый и последний день месяца, в котором автомобиль отправился в путь
Вот что имеется) Option Explicit Private Sub UserForm_Activate() txtT1 = Format(Now, &quot;d/m/yy h:mm&quot;) txtT2 =...

По числу текущего месяца определить день недели
По числу текущего месяца определить день недели Составьте программу с использованием команды ветвления и потом отдельно изменить...

С января 1990 года по некоторый день прошло m месяцев определить название текущего месяца
Сянваря 1990 года по некоторый день прошло m месяцев определить название текущего месяца


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Логарифм записывается как: (x-2)log(x^2+2) - означает логарифм (x^2+2) по основанию (x-2). Унарный минус обозначается как ! */ #include <iostream> #include <stack> #include <cctype>. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru