• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

关于SqlServer星期和C#星期被坑

mysql 搞代码 4年前 (2022-01-09) 33次浏览 已收录 0个评论

中国人习惯星期习惯是每周的周一是一个星期的第一天 但老外则是星期天是每周的第一天 但在sqlServer和C#中又有不同 在这里我也是被坑的很惨(先做了sqlServer的处理自以为C#和SqlServer是一样的处理就没多想 然后就。。。。。 死的很惨) 注:2015-01-5 是星期

中国人习惯星期习惯是每周的周一是一个星期的第一天 但老外则是星期天是每周的第一天

但在sqlServer和C#中又有不同 在这里我也是被坑的很惨(先做了sqlServer的处理自以为C#和SqlServer是一样的处理就没多想 然后就。。。。。 死的很惨)

注:2015-01-5 是星期一

sqlServer用函数 SELECT DATEPART(weekday, ‘2015-01-5’) 查询返回的是 2

C# DateTime类下面有个属性DayOfWeek ; Convert.ToDateTime(‘2015-01-5’).DayOfWeek; 获取返回的是 1

SqlServer的星期是从1-7 1:星期天 以此类推 7:星期六

C#的星期是从0-6 0:星期天 以此类推 6:星期六

如果要吧sqlServer和C#的时间星期转换成我们中国人的习惯星期 这这需要做下转换工作

sqlServer:

CREATE FUNCTION [dbo].[Get_TimeWeek] (@time datetime) returns int as       BEGIN		declare @sdate INT        declare @week INT		SET @sdate= DATEPART(weekday, @time)		SELECT @week=CASE			when @sdate =1 then 7 			when @sdate =2 then 1 			when @sdate =3 then 2 			when @sdate =4 then 3 			when @sdate =5 then 4 			when @sdate =6 then 5 			when @sdate =7 then 6  			else 0			END  		return @weekEND 

C#

        public static int CaculateWeekDay(DateTime time)        {                       int w = (int)time.DayOfWeek;            int week = 0;            switch (w)            {                case 0:                    week = 7;                    break;                case 1:                    week = 1;                    break;                case 2:                    week = 2;                    break;                case 3:     <em>本文来源[email protected]搞@^&代*@码2网</em>               week = 3;                    break;                case 4:                    week = 4;                    break;                case 5:                    week = 5;                    break;                case 6:                    week = 6;                    break;            }            return week;        }

搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:关于SqlServer星期和C#星期被坑

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址