c# mongodb时间类型字段保存时相差八个小时解决办法 – 屌丝大叔的笔记 – 博客园 -Mikel

c# mongodb时间类型字段保存时相差八个小时解决办法 – 屌丝大叔的笔记 – 博客园

2020年9月9日 分类: C#, Debug, 数据库
baacloud免费翻墙vpn注册使用

来源: c# mongodb时间类型字段保存时相差八个小时解决办法 – 屌丝大叔的笔记 – 博客园

        /// <summary>
        /// 添加时间
        /// </summary>
        [BsonDateTimeOptions(Kind = DateTimeKind.Local)]
        public DateTime CreatedTime { get; set; }

添加上面这个特性即可。添加了这个特性并不是说在保存时mongodb数据库的时间就是本地时间了。而是说在显示的时候mongodb驱动会根据这个特性自动转化成本地时间。实际存入数据库的还是0时区的时间。

为什么会这么说?在网上看了java mongodb驱动的源码,知道java是这么做的,然后.net应该也是。下面贴出java mongodb驱动的源码:

复制代码
        if (o instanceof Date) {
            Date d = (Date) o;
            SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss.SSS'Z'");
            format.setCalendar(new GregorianCalendar(new SimpleTimeZone(0, "GMT")));
            serialize(new BasicDBObject("$date", format.format(d)), buf);
            return;
        }
复制代码

从源码看到,只要遇到时间类型,不管你的时间值是多少,都会重新按照0时区生成时间。我们只能在显示的时候,转化成本地时间。






标签:
本文的评论功能被关闭了.
备案信息冀ICP 0007948