一,问题描述

数据格式: 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(greaterequal)表示“大于等于”。【gte(greaterequal)表示“大于等于”。【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);//组合 条件1andCondi.add(inCondi);//组合 条件2BasicDBObject 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);}}
}

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

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

    一,问题描述 数据格式: id, timeStamp,count 条件1:查询 某个时间段 内的数据: timeStamp BETWEEN startTime AND endTime.比如 timeS ...

  2. java mongodb $in_MongoDB 组合多个条件查询($and、$in、$gte、$lte)

    一,问题描述 数据格式: id, timeStamp,count 条件1:查询 某个时间段 内的数据: timeStamp BETWEEN startTime AND endTime.比如 timeS ...

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

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

  4. mongodb java 多条件查询_MongoDB_Java连接mongo 使用Java多条件查询mongo数据

    在mongo shell中的查询语句是这样的.. db.user.find({"age":{"$gt":5,"$lt":14}})我们用Ja ...

  5. php中条件查询语句,thinkphp3.2框架中where条件查询用法总结

    本文实例讲述了thinkphp3.2框架中where条件查询用法.分享给大家供大家参考,具体如下: thinkphp3.2 where 条件查询 在连贯操作中条件where的操作有时候自己很晕,所以整 ...

  6. MongoDB 添加、查询(条件查询、排序、分页、返回指定字段)、修改、删除数据、聚合aggregate

    MongoDB内部支持JavaScript语法,使用SpiderMonkey作为内部的JavaScript解释器引擎. 1.常用命令 show databases:显示数据库列表 use:切换数据库 ...

  7. mongodb java 多条件查询_MongoDB查询之高级操作详解(多条件查询、正则匹配查询等)...

    MongoDB查询之高级操作 语法介绍 MongoDB查询文档使用find()方法,同时find()方法以非结构化的方式来显示所有查询到的文档. -- 1.基本语法 db.collection.fin ...

  8. MongoDB自定义条件查询案例

    MongoDB自定义条件查询案例

  9. 01.query的分类-条件查询和组合查询

    文章目录 1. es单个条件查询和组合查询 2.query和filter context 1. query context 2. filter context 3.使用样例 1. es单个条件查询和组 ...

最新文章

  1. 2019年上半年收集到的人工智能LSTM干货文章
  2. C 函数别名简单记录
  3. python绘制笑脸-用python绘图
  4. 【工具篇】抓包中的王牌工具—Fiddler (1-环境搭建)
  5. C# DataRow数组转换为DataTable
  6. linux anaconda搜索路径,Anaconda安装及虚拟环境搭建教程(linux)
  7. 钱准备好!苹果官方账号泄密:iPhone 12明晚发布有戏
  8. 严阵以待的意思是什么,怎么用严阵以待造句?
  9. 四:Jquery-animate
  10. element el-upload上传图片完成后隐藏上传
  11. 语音识别(ASR) 阿里云
  12. 制作京东快报页面html,仿京东首页的京东快报,自动向上滚动的广告条
  13. java中英文排序_Java 中英文数字排序
  14. Kafka生产者和消费者
  15. 说说JS在IE中的内存泄露问题
  16. 《统计学习方法》(李航)第1章主要内容介绍(统计学习概述、分类、三要素)
  17. 【C库函数】strlen函数详解
  18. 小程序:小程序获取焦点事件
  19. 思科瘦AP开启telnet/ssh通过WLC命令方式
  20. 【数据结构】CH6 数组和广义表

热门文章

  1. 2022英雄联盟LPL春季赛什么时候开始
  2. 苹果史上最强的ARM芯片来了!这次的MacBook是真香了!!!
  3. 确认! Python再次夺冠,80%的程序员痛快!你怎么看?
  4. OPPO手机浏览器获取cookie异常
  5. Spring 拦截器流程及多个拦截器的顺序
  6. 适用于苹果电脑的数据恢复软件介绍
  7. 【灵感一剖】蚂蚁森林新神器-能量双击卡
  8. ubuntu网络重启命令
  9. windows修改电脑处理器个数利弊
  10. flutter 调用摄像头,前后镜头切换