gpt4 book ai didi

java - 使用 Java 驱动程序在 MongoDB 中进行高级逻辑运算

转载 作者:太空宇宙 更新时间:2023-11-04 13:55:13 25 4
gpt4 key购买 nike

我在使用 MongoDB 时遇到了一些问题,我正在尝试使用 Java 驱动程序创建一个包含多个运算符的查询。我正在寻找这样的东西:x1:y1 或(x2:y2 和 x3:y3)

目前我有这个:

 BasicDBObject andQuery = new BasicDBObject();

List<BasicDBObject> obj2 = new ArrayList<BasicDBObject>();
obj2.add(new BasicDBObject("x1", "y1"));
andQuery.put("$or", obj2);

List<BasicDBObject> obj = new ArrayList<BasicDBObject>();
obj.add(new BasicDBObject("x2", "y2"));
obj.add(new BasicDBObject("x3", "y3"));
andQuery.put("$and", obj);

当我打印时,这给了我这个:

 { "$or" : [ { "x1" : "x1"}] , "$and" : [ { "x2" : "x2"} , { "x3" : "y3"}]}

所以我认为问题出在第一个“]”上,它应该在最后,所以$and将在$or数组中。

但是我怎样才能做到这一点呢?谢谢!

最佳答案

试试这个:

BasicDBObject orQuery = new BasicDBObject();

List<BasicDBObject> obj = new ArrayList<BasicDBObject>();
obj.add(new BasicDBObject("x2", "y2"));
obj.add(new BasicDBObject("x3", "y3"));
andQuery.put("$and", obj);

List<BasicDBObject> obj2 = new ArrayList<BasicDBObject>();
obj2.add(new BasicDBObject("x1", "y1"));
obj2.add(andQuery);
orQuery.put("$or", obj2);

关于java - 使用 Java 驱动程序在 MongoDB 中进行高级逻辑运算,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29897782/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com