c# mongodb时间类型字段保存时相差八个小时解决办法

Posted subendong

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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时区生成时间。我们只能在显示的时候,转化成本地时间。

以上是关于c# mongodb时间类型字段保存时相差八个小时解决办法的主要内容,如果未能解决你的问题,请参考以下文章

C#与mongodb DateTime转换时区相差8小时

在MongoVUE中发现插入的时间和实际的时间相差8小时?

MongoDB时间类型

JsonFormat格式转换

西门子1200PLC系统时间与电脑系统时间相差8小时如何设定

MongoDB 日期类型查询