Я не смог найти решение, которое дает первый и последний день предыдущего месяца с отметкой времени. Надеюсь, это поможет другим. Если уже есть решение этой проблемы прошу прощения.
Вот решение.
SELECT DATEADD(month, DATEDIFF(month, -1, getdate()) - 2, 0) as FirtDayPreviousMonthWithTimeStamp,
DATEADD(ss, -1, DATEADD(month, DATEDIFF(month, 0, getdate()), 0)) as LastDayPreviousMonthWithTimeStamp
Это вернет следующее, еслиcurrentdate = '2012-7-31'
результат:2012-06-01 00:00:00.000 2012-06-30 23:59:59.000
Это вернет следующее, еслиcurrentdate = '2012-1-1'
результат:2011-12-01 00:00:00.000 2011-12-31 23:59:59.000