当前位置:  开发笔记 > 编程语言 > 正文

是否可以在MongoDB-Query中进行转换?

如何解决《是否可以在MongoDB-Query中进行转换?》经验,为你挑选了1个好方法。

当我有两个像这样的MongoDB文件时......

db.test.insert( {"value" : "10123"} );
db.test.insert( {"value" : "160"} );

查询的结果如:

db.test.find({"value" :{$gt : "12"} });

是..

{ "_id" : ObjectId("4c6d1b92304326161b678b89"), "value" : "160" }

很明显,进行了字符串比较,因此不会返回我的第一个值.有没有办法在查询中进行投射?

就像是:

db.test.find({ (int) "value" :{$gt : 12} });

会很好.像这样的查询

db.test.find({"value" :{$gt : 12} }); // without the quotes around "12"

没有回报.



1> Niels van de..:

您可以使用以下JavaScript表达式:

db.test.find("this.value > 12")

这使用JavaScript从字符串到数字的自动转换.


只是要小心,因为它不能使用索引
推荐阅读
惬听风吟jyy_802
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有