16

次の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解析エラーは、JavaScriptがmongoクエリの一部を評価するために使用されていることを知っています。私は疑問に思っていました:$gtおよび$lt演算子はjavascriptを必要としますか?それは私の問題ですか?そうでない場合は、クエリの何が問題になっているのかわかりません。提案をいただければ幸いです。読んでくれてありがとう!

4

1 に答える 1

53

ここでの問題は、日付をどのように表現するかです。日付は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をエポックに変換する場合は、シェルでdateを呼び出すだけです。次のようになります。

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

次に、確認します。

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

更新:imcaptorによるコメントに記載されているように、コンストラクターでは月はゼロベース(0 = 1月、11 = 12月)であり、Dateほとんどの人が期待するものではなく、忘れがちです。検証からISODateでわかるように、上記の例で01を渡し、2月の日付を取得しました。

于 2013-02-08T07:18:20.790 に答える