SQL 计算某月有多少天
2014-03-04 11:22
190 查看
今天用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
第一印象就是:要考虑到润年还是平年,再判断是大月还是小月,难道要写一个复杂的存储过程不可?
答案不是!
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
相关文章推荐
- SQL语句计算两个日期之间有多少个工作日的方法
- SQL 计算一个月有多少天
- SQL语句计算两个日期之间有多少个工作日的方法
- mysql 计算前多少天 sql语句
- sql计算百分比
- 【Transact-SQL】计算整个表中所有值的出现的次数
- SQL计算出百分比
- SQL dateadd 语句获得指定日期多少天之后的新日期
- 6.计算字段 ---SQL
- java计算两个日期相差多少天小时分钟等
- 利用jquery插件在客户端计算“过了多少时间”
- sql中时间日期操作(时间日期函数,时间日期格式,时间日期转换参数,时间日期比较,时间日期计算)
- sql中各种日期的计算方法~
- Calendar GregorianCalendar 计算某年有多少周 、周的开始结束日期、日期的周数
- 一个计算自己活了多少天的函数
- Java:计算出生到现在多少天代码
- mysql实现经纬度计算两个坐标之间的距离sql语句
- php计算两个日期相隔多少年,多少月,多少日的函数
- 今天开始学Java 给定一个正整数,编写程序计算有多少对质数的和等于输入的这个正整数,并输出结果。
- 实现任务:使用while计算:2006年培养学员8万人,每年增长25%,请问按此增长速度,到那一年培训学员数将是多少