为什么mongoexport在mongo可以不解析这个JSON?
问题描述:
这是查询:为什么mongoexport在mongo可以不解析这个JSON?
mongoexport --host our.dbhost.com --port 27017 --username peter -p clark --collection sent_mails --db dbname --query '{trigger_id:ObjectId("50c62e97b9fe6a000200000c"), updated_at: {$lt : ISODate("2013-02-28"), $gte : ISODate("2013-02-01") }}'
当我运行这个命令,我得到:
assertion: 10340 Failure parsing JSON string near: , updated_
什么想法? (我想匹配的是在二月份更新trigger_id的所有记录。)
答
在这个问题解释说:Mongoexport using $gt and $lt constraints on a date range,你必须在mongoexport使用Unix时间戳记日期查询
时间戳必须以毫秒为单位
bash shell中调用这个应该是这样的:
let "date_from=`date --utc --date "2013-02-01" +%s` * 1000"
let "date_to=`date --utc --date "2013-03-01" +%s` * 1000"
mongoexport -d test -c xx --query "{updated_at:{\$gte:new Date($date_from),\$lt:new Date($date_to)}}"> xx.json
> connected to: 127.0.0.1
> exported 1 records
的XX总汇包含:
> db.xx.find().pretty()
{
"_id" : ObjectId("5158f670c2293fc7aadd811e"),
"trigger_id" : ObjectId("50c62e97b9fe6a000200000c"),
"updated_at" : ISODate("2013-02-11T00:00:00Z")
}