引子 ##
这些天在使用spring mongodb的时候发现Query的add与andOperator有点相像,但始终没弄明白他们之间的区别,最后在网上查了一些相关资料顺便看了下源代码总算理解了。
“$and”如何工作
向good中插入100W数据。
for (var i=0; i<1000000; i++) {
db.good.insert({"x":[i, i+1, i+2, i+3, i+4]});
}
执行查询,查看是否有$and的区别
$and和不加$and的区别在于:
> db.good.find({"x":{"$lt":5,"$gt":1}})//相当于加了"$and"
{ "_id" : ObjectId("4ed061427ecbeebf00e65625"), "x" : [ 0, 1, 2, 3, 4 ] }
{ "_id" : ObjectId("4ed061427ecbeebf00e65626"), "x" : [ 1, 2, 3, 4, 5 ] }
{ "_id" : ObjectId("4ed061427ecbeebf00e65627"), "x" : [ 2, 3, 4, 5, 6 ] }
{ "_id" : ObjectId("4ed061427ecbeebf00e65628"), "x" : [ 3, 4, 5, 6, 7 ] }
{ "_id" : ObjectId("4ed061427ecbeebf00e65629"), "x" : [ 4, 5, 6, 7, 8 ] }
> db.good.find({"x":{"$lt":5}, "x":{"$gt":1}})
{ "_id" : ObjectId("4ed061427ecbeebf00e65625"), "x" : [ 0, 1, 2, 3, 4 ] }
{ "_id" : ObjectId("4ed061427ecbeebf00e65626"), "x" : [ 1, 2, 3, 4, 5 ] }
{ "_id" : ObjectId("4ed061427ecbeebf00e65627"), "x" : [ 2, 3, 4, 5, 6 ] }
{ "_id" : ObjectId("4ed061427ecbeebf00e65628"), "x" : [ 3, 4, 5, 6, 7 ] }
{ "_id" : ObjectId("4ed061427ecbeebf00e65629"), "x" : [ 4, 5, 6, 7, 8 ] }
{ "_id" : ObjectId("4ed061427ecbeebf00e6562a"), "x" : [ 5, 6, 7, 8, 9 ] }
{ "_id" : ObjectId("4ed061427ecbeebf00e6562b"), "x" : [ 6, 7, 8, 9, 10 ] }
{ "_id" : ObjectId("4ed061427ecbeebf00e6562c"), "x" : [ 7, 8, 9, 10, 11 ] }
{ "_id" : ObjectId("4ed061427ecbeebf00e6562d"), "x" : [ 8, 9, 10, 11, 12 ] }
......
具体可以参照$and详细使用情况
Criteria中”and”与”andOperator”方法的区别
注意是Criteria中,Query中也有andOperator方法。先看如下问题:
解答:
《问题来源链接》
在看看官方文档的说明:
由此,我们不难看出andOperator里面查询的是同一个字段多个约束的问题。现在如果在去看一下源代码,很明显就能看出他们直接的区别了。源代码我就不再做说明了。
ps:
mongoTemplate使用查询“复合索引”时需要使用and方法(不能用andOperator)。
因为and的多个条件在同一个大括号里,andOperator多个条件分别在各自的括号里。
(官方的复合索引示例都是在同一个大括号里)
转载自:https://blog.csdn.net/niclascage/article/details/47110051?utm_source=blogxgwz5