我正在通过 time.now()
使用 go 创建一个日期,并将其存储在 mongodb 中,没有任何问题。日期看起来像 2023-02-28t20:10:46.140+00:00
。
但是,当我尝试检索它时,我收到一条错误消息:
{{"code":2, "message":"parsing time \"2023-02-28 20:10:46.14 +0000 utc\" as \"2006-01-02t15:04:05z07:00\": cannot parse \" 20:10:46.14 +0000 utc\" as \"t\"", "details":[]}
它来自这段代码。
createdAt, err := time.Parse(time.RFC3339, blog.CreatedAt.String())
if err != nil {
return nil, err
}
updatedAt, err := time.Parse(time.RFC3339, blog.UpdatedAt.String())
if err != nil {
return nil, err
}
tempBlog := &api.Blog{
Id: blog.ID,
CreatedAt: timestamppb.New(createdAt),
UpdatedAt: timestamppb.New(updatedAt),
我在这里和这里找到了一些有用的文档,并将手动解析的时间添加到 mongo 中,但我仍然遇到了这个问题。
我已经尝试了所有时间格式,但它只会导致无法解析的不同错误。
建议?
正确答案
如果您存储 time.time
mongodb 会自动为您检索它。检索到的时间为 utc 时间,如果您想更改为本地时区,请使用 time.local()
。
package date_test
import (
"context"
"github.com/stretchr/testify/require"
"go.mongodb.org/mongo-driver/bson"
"go.mongodb.org/mongo-driver/mongo"
"go.mongodb.org/mongo-driver/mongo/options"
"os"
"testing"
"time"
)
type something struct {
name string `json:"name" bson:"name"`
createtime time.time `json:"createtime" bson:"createtime"`
}
func testdate(t *testing.t) {
raw := something{name: "demo", createtime: time.now()}
t.logf("raw: %v", raw)
ctx, cancel := context.withtimeout(context.background(), 20*time.second)
defer cancel()
client, err := mongo.connect(ctx, options.client().applyuri(os.getenv("uri")))
require.noerror(t, err)
collection := client.database("test").collection("demo")
_, err = collection.insertone(ctx, raw)
require.noerror(t, err)
var res something
err = collection.findone(ctx, bson.d{{"name", raw.name}}).decode(&res)
require.noerror(t, err)
t.logf("res: %v", res)
t.logf("local time: %v", res.createtime.local())
}
运行测试代码,它将打印类似这样的内容
$ uri="mongodb://127.0.0.1:27017/" go test -v ./date_test.go
=== run testdate
date_test.go:21: raw: {demo 2023-03-07 10:26:22.433473 +0800 cst m=+0.009080292}
date_test.go:32: res: {demo 2023-03-07 02:26:22.433 +0000 utc}
date_test.go:33: local time: 2023-03-07 10:26:22.433 +0800 cst
--- pass: testdate (0.01s)
pass
ok command-line-arguments 0.912s
mongo 像这样存储时间
> db.demo.find().pretty()
{
"_id" : ObjectId("6406a0ce4cfff0411ca8d98b"),
"name" : "demo",
"createTime" : ISODate("2023-03-07T02:26:22.433Z")
}
源代码在这里https://gist.github.com/alex-x -加密/14c15d4921f1ece2962302cce87c97a8
以上就是使用 golang time.Now() 解析 mongoDB 中的日期的详细内容,更多请关注编程网其它相关文章!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
软考中级精品资料免费领
- 历年真题答案解析
- 备考技巧名师总结
- 高频考点精准押题
- 资料下载
- 历年真题
193.9 KB下载数265
191.63 KB下载数245
143.91 KB下载数1148
183.71 KB下载数642
644.84 KB下载数2756