今天用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构造函数中的双引号改成单引号貌似就没有问题了。。。。