java mongodb 并表 group 查询 Bson

对mongodb的使用中,需要将发生额表occr+期初表open表,进行union的并表操作后,再进行group,sum,排序,分页操作。

查询了一番后,mongodb4.4版本后,新增了一个管道符,$unionWith,可以进行类似于sql里的union动作。

我原来的写法,是使用Aggregation,Criteria的类进行构造,然后使用mongotemplate进行查询,奈何寻找了一番,没有在Aggregation里找到,对应unionWith的构造方法。于是,只能转换写法,用最自由,类客户端查询的写法去写,如何读者们知道对应的unionWith构造方法,烦请评论区告知下。

其实mongodb的查询,写熟练了之后,还是挺简单的。

基本上就是这种写法,一系列动作,就是一个数组,每个动作用一个json对象进行包裹。

javascript 复制代码
[{},{},{}]

如果有and 和or的复杂组合查询,就是使用

javascript 复制代码
{"$or":[{filed1:值1,filed2:值1...},{filed1:值2,filed2:值2...}]}
{"$and":[{"$or":...}]}

这种多层级的json去操作,唯一要注意点的,就是层级关系而已。

本质就是json对象+数组的嵌套。

这里讲下unionWith的写法。

客户端的语句里,是如下形态

javascript 复制代码
{
     $unionWith:{
        "coll":"你要合并的集合名称",
        //要合并之前对这张新加入的表的一系列操作
        "pipeline":[{
            $match:{要合并之前对这张新加入的表的操作}
        },{
            $project:{}
        }]
    }
}

最好是在客户端实验过正确结果之后,再去转换成bson。

在客户端我们写查询,键没有带双引号,写json语句的时候,无所谓,都带上问题不大这里贴一下我在java组装union的写法

javascript 复制代码
import org.bson.Document;

List<Document> conditions = new ArrayList<>();

Document matchDoc = Document.parse("和客户端一样的查询json字符串");

conditions.add(matchDoc);

AggregateIterable<Document> resultSet =
        mongoTemplate.getCollection(collectionName).aggregate(conditions);

主要就是使用了MongoCollection<TDocument>接口的下列方法

javascript 复制代码
AggregateIterable<TDocument> aggregate(List<? extends Bson> var1);

最后,贴一下,这种写法,对查询出来数据的处理。

javascript 复制代码
try (MongoCursor<Document> cursor = resultSet.iterator()) {
      while (cursor.hasNext()) {
        JsonObject itemObj = gson.fromJson(cursor.next().toJson(), JsonObject.class);
    }
}

这里我主要是将查出来的document结果,转为了json字符串,再转回我习惯性使用的Gson工具包里的对象,主要是个人觉得这个Document对象太难用了,当然你也可以使用别的json工具包去转为你熟悉的json对象(在java里)

相关推荐
葫芦和十三2 小时前
图解 MongoDB 09|explain 再读:从 queryPlanner 到 executionStats
后端·mongodb·agent
葫芦和十三2 小时前
图解 MongoDB 10|覆盖查询:让索引把活干完,根本不用回表
后端·mongodb·agent
小bo波6 小时前
使用Thread子类创建线程 VS 使用Runnable接口创建线程的区别
java·多线程·thread·并发编程·runnable
SamDeepThinking6 小时前
高并发场景下,CompletableFuture与ForkJoinPool该如何取舍?
java·后端·面试
张不才9 小时前
CPU 100% 了怎么办?Java 性能排障的标准化操作
java·后端
shepherd11111 小时前
吞吐量提升 10 倍:高并发大批量数据处理任务的架构演进与性能调优
java·后端·架构
plainGeekDev13 小时前
单例模式 → object 声明
android·java·kotlin
用户2986985301414 小时前
Java 实现 Word 文档文本与图片提取的方法
java·后端
SimonKing15 小时前
铁子,IntelliJ IDEA 2026.1.3来了,升不升?
java·后端·程序员