C# DateTime类型和sqlserver DateTime精度不同
2024-09-02 21:52:19
在最近的项目中, 有个关于时间的功能。一个请假的时间。前端选择的时候只有日期。所以比如请一天假就是选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
最新文章
- linux下的代码比较工具
- CentOS7安装配置redis-3.0.0
- ABBYY如何使用电子邮件发送OCR结果
- asp.net 页面跳转传值的几种方式
- error: could not find library containing RSA_new
- [原创]cocos2d-x + Lua接入iOS原生SDK的实现方案
- 一行代码解决各种IE兼容问题,IE6,IE7,IE8,IE9,IE10(转)
- ANDROID 中UID与PID的作用与区别
- iOS AVAudioPlayer 提示音
- OpenCV学习 7:图像形态学:腐蚀、膨胀
- java 类与对象
- jq实现多选反选
- 自己手写一个queuelink
- Spring Boot + Spring Cloud 实现权限管理系统 配置中心(Config、Bus)
- mysql 5.7中的threads
- linux下/proc/diskstats文件详解
- 两台linux主机使用unison + inotify实现web文件夹同步
- ACM题目————Sunscreen
- ehci及其伴随ohci主机控制器驱动分析
- socket的protocal参数