javascript - Mongoexport 在日期范围内使用 $gt 和 $lt 约束

标签 javascript mongodb mongoexport

我正在尝试使用以下 mongoexport 调用从我的 mongodb 获取某一天的订单:

mongoexport --db store --collection user_data --query "{'order.created_order':{$gt:ISODate("2013-02-05T00:00:00.000Z"),$lt:ISODate ("2013-02-06T00:00:00.000Z")}, 'order.status':'paid'}"--out ordersfeb6.json

但我目前遇到以下错误:

Thu Feb  7 18:33:43 Assertion: 10340:Failure parsing JSON string near: 'order.cre
0x56a223 0x5712e5 0x53e0f7 0x53e21e 0x8b7739 0x524f2b 0x5258a3 0x7fa7b77bd76d 0x525975 
mongoexport(_ZN5mongo15printStackTraceERSo+0x23) [0x56a223]
mongoexport(_ZN5mongo11msgassertedEiPKc+0xc5) [0x5712e5]
mongoexport(_ZN5mongo8fromjsonEPKcPi+0x377) [0x53e0f7]
mongoexport(_ZN5mongo8fromjsonERKSs+0xe) [0x53e21e]
mongoexport(_ZN6Export3runEv+0x489) [0x8b7739]
mongoexport(_ZN5mongo4Tool4mainEiPPc+0x72b) [0x524f2b]
mongoexport(main+0x23) [0x5258a3]
/lib/x86_64-linux-gnu/libc.so.6(__libc_start_main+0xed) [0x7fa7b77bd76d]
mongoexport() [0x525975]
assertion: 10340 Failure parsing JSON string near: 'order.cre

来自这个问题 mongoexport JSON parsing error我知道 javascript 用于评估 mongo 查询的某些部分。我想知道:$gt 和 $lt 运算符是否需要 javascript,这是我的问题吗?如果没有,我不确定我的查询有什么问题,任何建议将不胜感激。感谢您的阅读!

最佳答案

这里的问题是您如何表示日期,它们需要以 Date 类型和纪元格式传入。试试这个:

mongoexport --db store --collection user_data --query '{"order.created_order":{$gt:new Date(1360040400000),$lt:new Date(1360990800000)}, "order.status" : "paid"}' --out ordersfeb6.json

如果您希望将 ISODate 转换为纪元,只需在 shell 中调用 date,如下所示:

> new Date(2013,01,16)*1
1360990800000

然后去验证:

> new Date(1360990800000)
ISODate("2013-02-16T05:00:00Z")

更新: 正如 imcaptor 的评论中所指出的,在 Date 构造函数中,月份是从零开始的(0 = Jan,11 = Dec),而不是大多数情况下期待,也容易忘记。我在上面的示例中通过了 01 并获得了 2 月的日期,正如您在验证中的 ISODate 中看到的那样。

关于javascript - Mongoexport 在日期范围内使用 $gt 和 $lt 约束,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14758605/

相关文章:

c# - 如何通过一次调用使用 mongodb C# 驱动程序添加嵌套元素或更新属性

mongodb - 如何使用 Mongoid 按嵌入文档中的字段对 MongoDB 集合进行排序?

mongodb - MongoDB高级聚合

javascript - SwaggerUI 在向 API 发出请求时生成一个端口号。有什么办法可以阻止这种行为吗?

javascript - 为 .show 创建延迟

javascript - 无法在 jQuery 中捕获事件

javascript - 前端或后端加密?

python - 将 Mongo 文档条目保存为 CSV + 格式化 ISODate

mongodb - 特定字符串长度的mongoexport导出?

mongodb - 如何设置mongoexport的数据类型