mongocxx:插入日期时间

问题描述 投票:1回答:1

我试图解析数据文件后,插入日期和时间为mongocxx,我的实际日期时间:

2007/12/01 00:00:00

也就是说,2007年12月1日午夜。我有这样的代码:

static bsoncxx::document::value make_doc(sm_struct const sm) {
    std::tm t{0};
    t.tm_sec = 0;
    t.tm_min=(int)sm.minute;
    t.tm_hour=(int)sm.hour;
    t.tm_mday=(int)sm.day-1;
    t.tm_mon=(int)sm.month;
    t.tm_year=sm.year-1900;
    t.tm_isdst = -1;
    std::time_t tt = mktime(&t);

    std::cout << sm.year << " " << t.tm_year << "/" << t.tm_mon << "/" << t.tm_mday << " " << t.tm_hour << ":" << t.tm_min << std::endl;
    bsoncxx::document::value document = bsoncxx::builder::basic::make_document(
        bsoncxx::builder::basic::kvp("datetime", bsoncxx::types::b_date{
            std::chrono::system_clock::from_time_t(tt)
        }),
    );
    return document;
}

运行我的代码,我得到这个在标准输出上:

2007 107/11/31 0:0

当我检查我的约会对象在数据库中,我得到:

ISODate("2007-12-30T13:30:00.000+0000")

怎么会在小时和分钟没有被正确设置在这里?

c++ mongodb chrono mongo-cxx-driver
1个回答
3
投票

它看起来是正确的,你插入2007年12月31日在阿德莱德当地时间午夜是二○○七年十二月三十〇日13:30(UTC)。您可以在显示它的UTC时间转换回本地时间。

Adelaide, Australia    Mon, 31 Dec 2007 at 00:00 ACDT    
UTC, Time Zone         Sun, 30 Dec 2007 at 13:30         

来源:timeanddate.com

© www.soinside.com 2019 - 2024. All rights reserved.