引子 ##

这些天在使用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

 

Logo

魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。

更多推荐