• 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

  • 相关阅读:
    LOJ3160 「NOI2019」斗主地
    常系数齐次线性递推
    最小树形图——朱刘算法学习小记
    Linux系统分区(一)
    Linux系统启动过程(二)
    Linux系统目录结构(三)
    cross_val_score
    sklearn.pipeline.Pileline
    DBSCAN密度聚类算法
    特征选择
  • 原文地址:https://www.cnblogs.com/EvanWay/p/8260368.html
Copyright © 2020-2023  润新知