[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 !