在最近的项目中, 有个关于时间的功能。一个请假的时间。前端选择的时候只有日期。所以比如请一天假就是选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().AddMilliseconds(-);

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

{-- ::}

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

{-- ::}

发现,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

最新文章

  1. linux下的代码比较工具
  2. CentOS7安装配置redis-3.0.0
  3. ABBYY如何使用电子邮件发送OCR结果
  4. asp.net 页面跳转传值的几种方式
  5. error: could not find library containing RSA_new
  6. [原创]cocos2d-x + Lua接入iOS原生SDK的实现方案
  7. 一行代码解决各种IE兼容问题,IE6,IE7,IE8,IE9,IE10(转)
  8. ANDROID 中UID与PID的作用与区别
  9. iOS AVAudioPlayer 提示音
  10. OpenCV学习 7:图像形态学:腐蚀、膨胀
  11. java 类与对象
  12. jq实现多选反选
  13. 自己手写一个queuelink
  14. Spring Boot + Spring Cloud 实现权限管理系统 配置中心(Config、Bus)
  15. mysql 5.7中的threads
  16. linux下/proc/diskstats文件详解
  17. 两台linux主机使用unison + inotify实现web文件夹同步
  18. ACM题目————Sunscreen
  19. ehci及其伴随ohci主机控制器驱动分析
  20. socket的protocal参数

热门文章

  1. linux 使用内存作为 /tmp 临时文件夹
  2. 用TIdIPWatch获取本地IP
  3. MyBatis入门程序(基于XML配置)
  4. sql server中的 trimtrailingblanks
  5. ROS(机器人URDF模型优化)
  6. jquery源码解析:val方法和valHooks对象详解
  7. Windows文件共享,报错"该用户已禁用"解决方案
  8. java日期时间
  9. bzoj3956: Count (单调栈+st表)
  10. MySQL中show语法