经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 数据库/运维 » MS SQL Server » 查看文章
获取某一年的天数
来源:cnblogs  作者:Insus.NET  时间:2019/5/10 8:54:30  对本文有异议

在MS SQL Server中,获取某一年的天数。

你可以先参考下面这篇《获取指定日期所属年份的第一天日期或最后一天日期https://www.cnblogs.com/insus/p/10839469.html


就可以使用MS SQL 的一个DATEDIFF函数算出这2个日期之间的日期间隔了。

 

  1. DECLARE @nowDate DATETIME = '2000-03-04'
  2.  
  3. SELECT DATEDIFF(
  4. DAY,
  5. [dbo].[svf_FirstDateOfTheYear](@nowDate),
  6. [dbo].[svf_LastDateOfTheYear](@nowDate)
  7. ) + 1
Source Code

 

也可以写成一个自定义Scalar-valued Function:

 

  1. SET ANSI_NULLS ON
  2. GO
  3. SET QUOTED_IDENTIFIER ON
  4. GO
  5. -- =============================================
  6. -- Author: Insus.NET
  7. -- Create date: 2019-05-09
  8. -- Update date: 2019-05-09
  9. -- Description: 获取指定日期所属年份的天数
  10. -- =============================================
  11. CREATE FUNCTION [dbo].[svf_DaysOfTheYear]
  12. (
  13. @TheYear DATETIME
  14. )
  15. RETURNS INT
  16. AS
  17. BEGIN
  18. RETURN DATEDIFF(
  19. DAY,
  20. [dbo].[svf_FirstDateOfTheYear](@TheYear),
  21. [dbo].[svf_LastDateOfTheYear](@TheYear)
  22. ) + 1
  23. END
Source Code

 

函数例子:

 

如果你能参考到这篇《指定日期,判断其所属年份是否为闰年 https://www.cnblogs.com/insus/p/10841868.html

获取年份的天数,这个函数会更简单:

 

平年的天数为365天,只在判断是否为闰年,如果是,即在平年的天数加1天即可:

 

原文链接:http://www.cnblogs.com/insus/p/10840807.html

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号