MongoDB 组合多个条件查询(and、and、in、gte、gte、lte)

本文涉及的产品
云数据库 MongoDB,独享型 2核8GB
推荐场景:
构建全方位客户视图
简介:

一,问题描述

数据格式: id, timeStamp,count

条件1:查询 某个时间段 内的数据: timeStamp BETWEEN startTime AND endTime。比如 timeStamp BETWEEN 1499875200  AND 1499875600

条件2:记录 的 id 字段 属于某集合: id IN (1001,1002,1003)

条件3:记录 的count字段 大于某个阈值,比如: count > 10000

 

二,代码实现

条件1实现如下,  g t e g r e a t e r e q u a l lte(lower equal)】表示“小于等于”

    private DBObject timeCondi(long startTimeStamp, long endTimeStamp){
        DBObject queryCondition = new BasicDBObject("$gte", startTimeStamp).append("$lte", endTimeStamp);
        BasicDBObject query = new BasicDBObject("timeStamp", queryCondition);
        return query;
    }

 

条件2的实现如下,使用 $in ArrayList<Integer> 来表示 id IN (1001,1002,1003)

复制代码
    private DBObject inCondi() {
        List<Integer> idList = new ArrayList<Integer>();
        idList.add(1001);
        idList.add(1002);
        idList.add(1003);

        BasicDBObject inQuery = new BasicDBObject();
        inQuery.put("id", new BasicDBObject("$in", idList));
        return inQuery;
    }
复制代码

 

组合条件1 和 条件2 查询:(条件1 AND 条件2).List 将所有 AND 组合的条件add进去,然后使用 $and 组合。

复制代码
    private DBObject andQuery(long startTimeStamp, long endTimeStamp) {
        DBObject timeCondi = timeCondi(startTimeStamp, endTimeStamp);
        DBObject inCondi = inCondi();

        List<DBObject> andCondi = new ArrayList<DBObject>();
        andCondi.add(timeCondi);//组合 条件1
        andCondi.add(inCondi);//组合 条件2

        BasicDBObject andQuery = new BasicDBObject();
        andQuery.put("$and", andCondi);
        return andQuery;
    }
复制代码

 

条件3:记录 的count字段 大于某个阈值,比如: count > 10000

    private DBObject countCondi(int size) {
        DBObject queryCondition = new BasicDBObject("$gte", size);
        BasicDBObject query = new BasicDBObject("count", queryCondition);
        return query;
    }

 

WINDOWS下安装好MongoDB后,MongoDB采用Clietn--Server 模式。WIN10下启动MongoDB服务端:-dbpath 指定 数据存储目录(可自己指定一个)

D:\Program Files\MongoDB\Server\3.4\bin>.\mongod.exe -dbpath ..\data

 

另起一个 Cmd命令行,输入:

D:\Program Files\MongoDB\Server\3.4\bin>.\mongo.exe

就可以以Shell方式操作MongoDB了。

输入 exit 退出

D:\Program Files\MongoDB\Server\3.4\bin>netstat -ano | findstr 27017  查看端口是否开启

另外,推荐一个MongoDB的可视化工具:RoboMongoDB。执行相应的查询语句如下:

 

 

三,新版本MongoDB(3.0版本以上),使用Filters来组合多个条件

查询 timeStamp 在[startTimeStamp, endTimeStamp) 内的所有document

1     private static Bson timeBetweenCondition(long startTimeStamp, long endTimeStamp) {
2         Bson condition = Filters.and(Filters.gte("timeStamp", startTimeStamp), Filters.lt("timeStamp", endTimeStamp));
3         return condition;
4     }

 

上面的示例,使用Filters的and方法连接了两个条件,其实还可以连接多个条件:比如查询 timeStamp 在[startTimeStamp, endTimeStamp) 区间内,并且 uid 在List<Long>uids 内的document

1     private static Bson multipleAndCondition(long startTimeStamp, long endTimeStamp, List<Long> uids) {
2         Bson condition = Filters.and(Filters.gte("timeStamp", startTimeStamp), Filters.lt("timeStamp", endTimeStamp), Filters.in("uid", uids));
3         return condition;
4     }

 

Filters还组合了 IN 条件:比如,查询 uid 在[123, 456, 789]中,可用如下条件:

1     private static Bson uidInCondition(List<Long> uids) {
2         Bson condition = Filters.in("uid", uids);
3         return condition;
4     }

 具体更多的条件查询,可查看Filters的源代码。关于Filters的更多的用法可参考:Filters的若干使用示例

 

四,MongoDB查询时,过滤某些字段

使用Document对象来指定需要查询或者排除的字段。0 表示不返回该字段的值,1 表示返回该字段的值。

复制代码
1     //0 表示 不返回 该字段, 1 表示 返回该字段
2     private static Document fetchFields() {
3         Document fetchFields = new Document();
4         fetchFields.put("_id", 0);//查询的结果 不返回 _id 字段
5         fetchFields.put("uid", 1);//返回 uid 字段
6         fetchFields.put("chat", 1);//返回 chat 字段
7         return fetchFields;
8     }
复制代码

然后再将 fetchFields 对象传入 project()方法即可,如下:

collection.find(timeBetweenCondition(startTimeStamp, endTimeStamp)).projection(fetchFields())

 

整个完整示例参考:

复制代码
import com.mongodb.MongoClient;
import com.mongodb.client.MongoCollection;
import com.mongodb.client.MongoCursor;
import com.mongodb.client.MongoDatabase;
import com.mongodb.client.model.Filters;
import org.bson.Document;
import org.bson.conversions.Bson;

import java.time.LocalDateTime;
import java.time.ZoneId;
import java.util.Arrays;
import java.util.List;
//import static com.mongodb.client.model.Filters.*;

/**
 * Created by Administrator on 2017/10/20.
 */
public class MongoUtil {
    private static final String HOST = "localhost";
    private static final int PORT = 27017;
    private static final String DB_NAME = "test";
    private static final MongoClient mongoClient = new MongoClient(HOST, PORT);
    private static MongoDatabase getDataBase() {
        return mongoClient.getDatabase(DB_NAME);
    }

    private static MongoCollection<Document> getCollection(String collName) {
        return getDataBase().getCollection(collName);
    }

    private static Bson timeBetweenCondition(long startTimeStamp, long endTimeStamp) {
        Bson condition = Filters.and(Filters.gte("timeStamp", startTimeStamp), Filters.lt("timeStamp", endTimeStamp));
        return condition;
    }

    private static Bson uidInCondition(List<Long> uids) {
        Bson condition = Filters.in("uid", uids);
        return condition;
    }

    private static Bson multipleAndCondition(long startTimeStamp, long endTimeStamp, List<Long> uids) {
        Bson condition = Filters.and(Filters.gte("timeStamp", startTimeStamp), Filters.lt("timeStamp", endTimeStamp), Filters.in("uid", uids));
        return condition;
    }


    //0 表示 不抽取该字段, 1 表示 抽取该字段
    private static Document fetchFields() {
        Document fetchFields = new Document();
        fetchFields.put("_id", 0);//查询的结果 不返回 _id 字段
        fetchFields.put("uid", 1);//返回 uid 字段
        fetchFields.put("chat", 1);//返回 chat 字段
        return fetchFields;
    }

    public static void main(String[] args) {
        MongoCollection collection = getCollection("mycollection_name");
        LocalDateTime today = LocalDateTime.of(2017, 8, 29, 0, 0, 0);
        LocalDateTime tomorrow = today.plusDays(1);

        long startTimeStamp = today.atZone(ZoneId.systemDefault()).toEpochSecond();
        long endTimeStamp = tomorrow.atZone(ZoneId.systemDefault()).toEpochSecond();
        Bson andCondition = multipleAndCondition(startTimeStamp, endTimeStamp, Arrays.asList(65496L));

//        Bson andCondition = timeBetweenCondition(startTimeStamp, endTimeStamp);
        Document fetchFields = fetchFields();
        MongoCursor<Document> cursor = collection.find(andCondition).projection(fetchFields).iterator();

        long count = collection.count(andCondition);
        System.out.println(count);
        while (cursor.hasNext()) {
            Document document = cursor.next();
            String chat = (String) document.get("chat");
            Long uid = (Long) document.get("uid");
            System.out.println("chat:" + chat + ", uid:" + uid);
        }
    }
}
复制代码

 

 

五:参考文献

https://www.mkyong.com/mongodb/java-mongodb-query-document/

http://farenda.com/mongodb/mongodb-filtering-sorting-and-projections/

本文转自hapjin博客园博客,原文链接:http://www.cnblogs.com/hapjin/p/7450309.html,如需转载请自行联系原作者

相关实践学习
MongoDB数据库入门
MongoDB数据库入门实验。
快速掌握 MongoDB 数据库
本课程主要讲解MongoDB数据库的基本知识,包括MongoDB数据库的安装、配置、服务的启动、数据的CRUD操作函数使用、MongoDB索引的使用(唯一索引、地理索引、过期索引、全文索引等)、MapReduce操作实现、用户管理、Java对MongoDB的操作支持(基于2.x驱动与3.x驱动的完全讲解)。 通过学习此课程,读者将具备MongoDB数据库的开发能力,并且能够使用MongoDB进行项目开发。 &nbsp; 相关的阿里云产品:云数据库 MongoDB版 云数据库MongoDB版支持ReplicaSet和Sharding两种部署架构,具备安全审计,时间点备份等多项企业能力。在互联网、物联网、游戏、金融等领域被广泛采用。 云数据库MongoDB版(ApsaraDB for MongoDB)完全兼容MongoDB协议,基于飞天分布式系统和高可靠存储引擎,提供多节点高可用架构、弹性扩容、容灾、备份回滚、性能优化等解决方案。 产品详情: https://www.aliyun.com/product/mongodb
相关文章
|
1月前
|
存储 NoSQL MongoDB
掌握MongoDB索引优化策略:提升查询效率的关键
在数据库性能调优中,索引是提升查询效率的利器。本文将带你深入了解MongoDB索引的内部工作原理,探讨索引对查询性能的影响,并通过实际案例指导如何针对不同的查询模式建立有效的索引。不仅将涵盖单一字段索引,还会探讨复合索引的使用,以及如何通过分析查询模式和执行计划来优化索引,最终实现查询性能的最大化。
|
25天前
|
存储 NoSQL MongoDB
MongoDB 查询分析
10月更文挑战第21天
11 1
|
25天前
|
NoSQL MongoDB 索引
MongoDB 覆盖索引查询
10月更文挑战第21天
23 1
|
1月前
|
SQL NoSQL MongoDB
MongoDB 查询文档
10月更文挑战第15天
14 1
|
1月前
|
人工智能 NoSQL 机器人
MongoDB Atlas与YoMio.AI近乎完美适配:推理更快速、查询更灵活、场景更丰富
随着MongoDB的新发布和革新,YoMio.AI的“闪电式发展”值得期待。
|
5月前
|
NoSQL 定位技术 MongoDB
解锁MongoDB索引的秘密:优化查询效率与应对限制的策略
解锁MongoDB索引的秘密:优化查询效率与应对限制的策略
|
2月前
|
SQL NoSQL JavaScript
04 MongoDB各种查询操作 以及聚合操作总结
文章全面总结了MongoDB中的查询操作及聚合操作,包括基本查询、条件筛选、排序以及聚合管道的使用方法和实例。
79 0
|
3月前
|
JSON NoSQL MongoDB
MongoDB Schema设计实战指南:优化数据结构,提升查询性能与数据一致性
【8月更文挑战第24天】MongoDB是一款领先的NoSQL数据库,其灵活的文档模型突破了传统关系型数据库的限制。它允许自定义数据结构,适应多样化的数据需求。设计MongoDB的Schema时需考虑数据访问模式、一致性需求及性能因素。设计原则强调简洁性、查询优化与合理使用索引。例如,在构建博客系统时,可以通过精心设计文章和用户的集合结构来提高查询效率并确保数据一致性。正确设计能够充分发挥MongoDB的优势,实现高效的数据管理。
64 3
|
3月前
|
存储 NoSQL MongoDB
【掌握MongoDB】轻松精通MongoDB查询,从基础到高级一网打尽!
【8月更文挑战第24天】在数据驱动的时代,数据库的性能与灵活性对企业至关重要。MongoDB作为一种高性能、无模式的文档数据库,为开发者提供了灵活的数据存储方案。尤其在处理半结构化或多变数据时展现出强大优势。本文重点介绍MongoDB中的查询操作,包括基本查询、条件查询、复杂查询以及字段选择、排序和限制等功能。通过掌握这些基本查询技巧,开发者能够有效从MongoDB中检索数据,支持复杂的业务逻辑。
61 1
|
3月前
|
监控 NoSQL MongoDB
mongodb查询100万数据如何查询快速
综上,提高MongoDB百万级数据的查询性能需要综合多项技术,并在实际应用中不断调优和实践。理解数据的特征,合理设计索引,优化查询语句,在数据访问、管理上遵循最佳的实践,这样才能有效地管理和查询大规模的数据集合。
214 1