Failed: error parsing query as json: invalid character '-' after constructor argument

今天用mongodb的mongodump备份数据,添加了一个-q命令,用来进行日期筛选

具体的命令大概是这样的

mongodump -h localhost:27017 -u admin -p xxx -d dbname -c c1 -o D:dbname -q "{"StartTime":{"$lt":ISODate("2020-12-02T00:00:00.000+08:00")}}" --authenticationDatabase admin

结果报错 Failed: error parsing query as json: invalid character '-' after constructor argument

我将{"StartTime":{"$lt":ISODate("2020-12-02T00:00:00.000+08:00")}}放到db中查询就不会报错

命令大概是这样的

db.getCollection('c1').find({"StartTime":{"$lt":ISODate("2020-12-02T00:00:00.000+08:00")}})

为什么放到find里面就正常,放到mongodump命令中就报错呢

提示说是构造函数后面的无效字符”-“,这个提示误导了我,折腾了老半天我才发现,原来是双引号的锅

db.getCollection('c1').find是个函数,里面传递的是一个json对象,ISODate的构造函数传入的是一个字符串,这是完全没有问题的

但是mongodump是个命令,-q后面跟的是一个字符串,字符串用双引号引起来,键用双引号好像没有问题,但是值ISODate构造函数传入的字符串也用了双引号,好像就出问题了,我把ISODate构造函数中的双引号改成单引号貌似就没有问题了。。。。

原文地址:https://www.cnblogs.com/luludongxu/p/14084726.html