今天用SQL Server 2005写查询语句,要求计算一个月平均每天发生的金额。以前往往喜欢查询相关的所有列,在代码中进行计算,还没有在SQL中写过。
第一印象就是:要考虑到润年还是平年,再判断是大月还是小月,难道要写一个复杂的存储过程不可?
答案不是!
SQL 中取出一个日期的天数提供一个内置函数:datepart(dp, date)
dp指:指定要返回的日期部分的参数。比如:返回日期可以用dd、d或者day;返回年份可以用yy、yyyy或者year
date指:要计算的日期。
比如:selectDatePart(day,'2008-10-12')
--显示12
还有一个内置函数:dateadd(dp, number, date)
dp指:指定要作为新值返回的日期部分的参数
number指:增加的数量(整数)
date指:要计算的日期。
比如:selectDateAdd(day, 3,'2008-10-10')
--返回2008-10-13 00:00:00.000
最后结合这两个函数,就可以计算一个月一共有多少天(计算2008-10)
selectDatePart(day,DateAdd(day,-1,'2008-11-1')) --返回 31
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix