C# DateTime类型和sqlserver DateTime精度不同

在最近的项目中, 有个关于时间的功能。一个请假的时间。前端选择的时候只有日期。所以比如请一天假就是选2017-8-15和2017-8-15,这样算请这一天的假。但是后台存入数据库时我不能就存2017-8-15 00:00:00和2017-8-15 00:00:00。这样区分不出时间。

我打算一个就存2017-8-15 00:00:00。另一个就2017-8-15 23:59:59这样子。这样子存进数据库。其他地方判断时才能确定是否在这个时间段内。

然后我就去百度了,直接找到这个代码,觉得很合理就上了、

toDate = toDate.Date.AddDays(1).AddMilliseconds(-1);

就是加一天嘛,然后减去1毫秒
C#中看时间也成功变成

{2017-8-15 23:59:59}

相当棒,直接就上,但是发现存进数据库里,时间变成了

{2017-8-16 00:00:00}

发现,datetime类型的时间精度是3.33毫秒,超过该精度会进行近似到0.000,0.003,0.007 秒

所以存到SQL Server的时候被round到了2017/8/16 00:00:000000

解决方法:
1、sqlserver DateTime换成datetime2类型(SQL Server 2008及以上版本才有),这样C# 的时间精度就和DateTime2的时间精度相同了
2、我们也别减1毫秒了、减1秒吧。这里把AddMilliseconds改成AddSecond(-1)减1s好了。


PS.附上我参考的文章,其实我也是找啊找才知道这个原因的

http://www.cnblogs.com/yangecnu/p/Difference-between-DotNet-DateTime-and-SQLServer-datetime.html

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 国家电网公司企业标准(Q/GDW)- 面向对象的用电信息数据交换协议 - 报批稿:20170802 前言: 排版 ...
    庭说阅读 11,211评论 6 13
  • 曾经有一份美好的爱情放在我的面前我没有珍惜。等到失去后才后悔莫及。如果可以再对小李说。毛欣想说。这辈子无缘再牵手。...
    毛欣与小李阅读 2,696评论 0 13
  • 语 句 功 能 数据操作 SELECT——从数据库表中检索数据行和列INSERT——向数据库表添加新数据行DELE...
    戰敭阅读 5,129评论 0 53
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,026评论 19 139
  • 晨起心情好,显摆显摆师傅的墨宝,老师的空间真丰富啊,努力做到好好学习天天向上哈 2017.6.15
    艳青阅读 249评论 2 2