Я не мог найти решение, которое дает первый и последний день предыдущего месяца с меткой времени. Надеюсь, это поможет другим. Если для решения этой проблемы уже есть решение, я извиняюсь.
Вот решение.
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