spring mongodb Criteria中"and"与"andOperator"方法的区别及"$and"如何工作(附:复合索引)

引子 ##

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

 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值