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

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

09.10.2017, 13:09. Показов 52166. Ответов 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
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru