一,问题描述

数据格式: 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实现如下, $gte (greater equal)表示“大于等于 ”。【$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

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

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

     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;
}

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

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

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

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

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

     //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;
}

然后再将 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/

原文:http://www.cnblogs.com/hapjin/p/7450309.html

MongoDB 组合多个条件查询($and、$in、$gte、$lte)的更多相关文章

  1. MongoDB 字符串值长度条件查询

    在实际项目中常常会有根据字段值长度大小进行限制查询,例如查询商品名称过长或过短的商品信息,具体的实现方式可能有多种,在此记录常见的两种实现 使用 $where 查询(性能稍逊一些) 1 2 3 4 5 ...

  2. mongodb将时间作为条件查询

    db.stock_signal_single.find({"createtime": { "$lt" : ISODate("2019-04-08T00 ...

  3. MongoDB学习笔记三:查询

    MongoDB中使用find来进行查询.查询就是返回一个集合中文档的子集,子集合的范围从0个文档到整个集合.find的第一个参数决定了要返回哪些文档,其形式也是一个文档,说明要执行的查询细节.空的查询 ...

  4. spring mvc 4.3.2 + mybatis 3.4.1 + mysql 5.7.14 +shiro 幼儿园收费系统 之 动态组合条件查询

    实际应用中,系统设计无法预料到用户最终的查询条件是怎样的.通常的做法是给出一些限制死的查询条件让用户查询.业务稍有改动,就要重新设计界面,增加查询字段等,费时费力. 比较好的做法是,除了常用的查询外, ...

  5. Mongodb 条件查询

    1.1 查询出所有数据的指定键(name ,age ,country) db.persons.find({},{name:1,age:1,country:1,_id:0}) 2.查询条件 2.查询条件 ...

  6. 【Mongodb教程 第十九课 】PHP与MONGODB的条件查询

    与普通的关系型数据库类似,在对数据的删.改.查的时候,会用到查询条件,如mysql中的 where… 而MongoDB中,经过php来做的所有的操作指令都是用array来包裹的: MongoColle ...

  7. mongodb复杂条件查询 (or与and)

    分类专栏: mongodb   版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接:https://blog.csdn.net/tjbsl/ ...

  8. mongodb根据字符长度作为条件查询

    { $where:"this.XXX.length==2" } 用$where条件查询,等号要用==.虽说$where查询可能效率不是很好,这只是我能想到的,有更好的方法欢迎指教

  9. spring mongodb分页,动态条件、字段查询

    使用MongRepository public interface VideoRepository extends MongoRepository<Video, String> { Vid ...

随机推荐

  1. 前端面试题整理—jQuery篇

    1.为什么使用jquery,他有哪些好处? 1)轻量级.代码简洁 2)强大的选择器,出色的DOM操作封装 3)有可靠的事件处理机制 4)浏览器兼容性好 5)支持链式操作 6)支持丰富的插件 2.jqu ...

  2. MarkDown 的两种页内跳转方法!!!!!

    页面内跳转就是点击某个文本,能够跳转到页面里指定的其他地方,经常用于目录中. 第一种是利用Html5 比如点击Feature, 跳转到features中 MarkDown: [Feature](#1) ...

  3. github及git使用

    一.github及git Github用于托管和协作项目的网站,git是通常与github一起使用的版本控制系统.Github上有上百万个开源项目,在使用git的时候每个开发人员都在他们的计算机上有一 ...

  4. pyhon 模块 IP/端口 扫描

    用到了python-nmap模块(注意是 python-nmap模块 不是nmap模块 且不要安装nmap模块!!!!) windows 中还需要下载一个 nmap 软件: 下载地址: https:/ ...

  5. PGCD2 - Primes in GCD Table (Hard)

    这题肝了三四天,其他啥也没做... 传送门 然后...双倍经验 简单版 不知道为什么会脑抽去帮 LZ_101 大佬验题... 题目和被 A 穿的 PGCD 一样,数据范围变成大概 2e11 ... 于 ...

  6. Copley-STM32串口+CANopen实现双电机力矩同步

    原来有个CANopen的主站卡,现在没了,只有单片机,用单片机来制作一个CANopen的主站卡貌似不是很难,但是需要时间.无奈仔细看了一个Copley的说明,决定采用CAN口+串口来实现之前的功能. ...

  7. Mysql --数据的增删改

    插入数据 INSERT 更新数据 UPDATE 删除数据 DELETE 一. 在mysql管理软件中,可以通过SQL语句中的DML语言来实现数据的操作,包括 1.使用insert实现数据的插入 2.u ...

  8. 【原创】大叔问题定位分享(9)oozie提交spark任务报 java.lang.NoClassDefFoundError: org/apache/kafka/clients/producer/KafkaProducer

    oozie中支持很多的action类型,比如spark.hive,对应的标签为: <spark xmlns="uri:oozie:spark-action:0.1"> ...

  9. vue 动态变量值不变化

    caseData = { lists:[] }; vm = new Vue({ el: '.hs-mt', data: caseData }); function getlist(pid,id){ $ ...

  10. 【sklearn】中文文档

    看不见的叫做远方 飞机票 分类   回归     聚类 降维   模型选择  预处理