zoukankan      html  css  js  c++  java
  • 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构造函数中的双引号改成单引号貌似就没有问题了。。。。

  • 相关阅读:
    tap事件的原理详解
    获取地理位置
    获取高度
    JSON字符串与JSON对象的区别
    zepto方法
    javascript 中 click 和onclick有什么区别呢
    oninput,onpropertychange,onchange的用法和区别
    js实时监听input中值得变化
    sql lock
    数据库SQL优化大总结
  • 原文地址:https://www.cnblogs.com/luludongxu/p/14084726.html
Copyright © 2011-2022 走看看