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

  • 相关阅读:
    访问 IIS 元数据库失败
    C# List<T>运用
    Unicode 数据
    讲解SQL Server 2000的Collection排序规则
    delphi Format用法
    delphi 文件的操作
    class of 语句
    深入delphi编程
    delphi 事件委托 未看
    如何让delphi在启动时不自动创建空的工程?
  • 原文地址:https://www.cnblogs.com/EvanWay/p/8260368.html
Copyright © 2011-2022 走看看