zoukankan      html  css  js  c++  java
  • 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

  • 相关阅读:
    条件变量:为什么要与互斥锁配套使用?为什么要使用while来避免虚假唤醒?
    【转】高性能IO之Reactor模式
    LeetCode127:单词接龙
    CF1245F: Daniel and Spring Cleaning
    权值线段树学习笔记
    luogu_4317: 花神的数论题
    luogu_2605: 基站选址
    入门平衡树: Treap
    CF1244C: The Football Season
    luogu_1156: 垃圾陷阱
  • 原文地址:https://www.cnblogs.com/EvanWay/p/8260368.html
Copyright © 2011-2022 走看看