[root@mongo ~]# bash -x t.sh

+ /usr/local/mongodb/bin/mongo 127.0.0.1:37017/test -uadmin -padmin --quiet --eval 'printjson(db.tickets.findOne({date:{:ISODate(2013-01-10T01:16:33.303Z)}},{_id:1}))'

Fri Apr 26 15:32:49 SyntaxError: invalid property id (shell eval):1

 

用bash来进行调试问题,会在界面输出执行命令

 /usr/local/mongodb/bin/mongo 127.0.0.1:37017/test -uadmin -padmin --quiet --eval "printjson(db.tickets.findOne({"date":{\$lt:ISODate(\"2013-01-10T01:16:33.303Z\")}},{"_id":1}))"

 

-- 在赋予变量的时候,有的转义需要赋予2个\\才行,比如$lt等 

在``里的\$lt运行之前就被转义成$lt,但是在运行时$lt又被执行了,然后就是空。``里的\\$lt解析时被转义成\$lt,运行时就是$lt了,应该就是这样的。

 

[root@mongo ~]# bash -x m.sh

+ (( i=1 ))

+ (( i<=2 ))

++ /usr/local/mongodb/bin/mongo 127.0.0.1:37017/test -uadmin -padmin --quiet --eval 'printjson(db.tickets.findOne({date:{$lt:ISODate("2013-01-10T01:16:33.303Z")}},{_id:1}))'

+ objectid='{ "_id" : ObjectId("5178bbaf7d2823c22b9ae0c8") }'

+ (( i++ ))

+ (( i<=2 ))

++ /usr/local/mongodb/bin/mongo 127.0.0.1:37017/test -uadmin -padmin --quiet --eval 'printjson(db.tickets.findOne({date:{$lt:ISODate("2013-01-10T01:16:33.303Z")}},{_id:1}))'

+ objectid='{ "_id" : ObjectId("5178bbaf7d2823c22b9ae0c8") }'

+ (( i++ ))

+ (( i<=2 ))

[root@mongo ~]#

 

now, it  is okay !

Logo

讨论HarmonyOS开发技术,专注于API与组件、DevEco Studio、测试、元服务和应用上架分发等。

更多推荐