使用SQL返回每个月的最后一天

前端之家收集整理的这篇文章主要介绍了使用SQL返回每个月的最后一天前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一个表,其中包含多个年中每个月的多个记录.有人可以帮我编写一个只返回每个月最后一天的查询.

解决方法

sql Server(其他DBMS将以相同或非常相似的方式工作):
SELECT
  *
FROM
  YourTable
WHERE
  DateField IN (
    SELECT   MAX(DateField)
    FROM     YourTable
    GROUP BY MONTH(DateField),YEAR(DateField)
  )

DateField上的索引在这里很有用.

PS:如果您的DateField包含时间值,上面的内容将为您提供每月的最后一条记录,而不是最后一天的记录.在这种情况下,使用方法在进行比较之前将日期时间减少到其日期值,例如this one.

猜你在找的MsSQL相关文章