java mongodb查询条件

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java mongodb查询条件相关的知识,希望对你有一定的参考价值。

BasicDBList condList = new BasicDBList();
BasicDBObject cond = null;
DBCollection coll = db.getCollection("test");
BasicDBList values = new BasicDBList();
values.add(10);
values.add(15);
cond = new BasicDBObject();
cond.put("age",new BasicDBObject("$in",values));
condList.add(cond);
BasicDBObject searchCond = new BasicDBObject();
searchCond.put("$and", condList);
DBCursor ret = coll.find(searchCond);
List<DBObject> list2 = ret.toArray();
for (int i = 0; i < list2.size(); i++)
System.err.println(list2.get(i));


我要查询出 age等于10 和等于15的 , 这个查不出来,,,请问我哪错了

java操作mongodb进行查询,常用筛选条件的设置如下:

条件列表:
BasicDBList condList = new BasicDBList();
临时条件对象:
BasicDBObject cond = null;
DBCollection coll = db.getCollection("A");

1、$where
在某种应用场合,若要集合A查询文档且要满足文档中某些属性运算结果,可以编写一脚本函数用where进行设置,比如:
某集合中存放的用户信息,包括姓名、年龄、手机号、地址等,要筛选出年龄大于20且小于等于40的用户,我们可以这样:
String ageStr = "function ()return parseFloat(this.age) > 20 && parseFloat(this.age) <= 40;";
cond = new BasicDBObject();
cond.put("$where",ageStr);

放入条件列表
condList.add(cond);

2、$in
接1实例中,要查询年龄为23、40、50的用户信息,我们可以这样:
创建一个临时的条件列表对象,将条件值分别添加进去
BasicDBList values = new BasicDBList();
values.add(23);
values.add(40);
values.add(50);

cond = new BasicDBObject();
cond.put("age",new BasicDBObject("$in",values));

放入条件列表
condList.add(cond);

3、模糊匹配
接1实例中,要按照用户的姓名进行模糊查询,如:王,我们可以这样做:

使用不区分大小写的模糊查询
3.1完全匹配
Pattern pattern = Pattern.compile("^王$", Pattern.CASE_INSENSITIVE);
3.2右匹配
Pattern pattern = Pattern.compile("^.*王$", Pattern.CASE_INSENSITIVE);
3.3左匹配
Pattern pattern = Pattern.compile("^王.*$", Pattern.CASE_INSENSITIVE);
3.4模糊匹配
Pattern pattern = Pattern.compile("^.*王.*$", Pattern.CASE_INSENSITIVE);

cond = new BasicDBObject();
cond.put("name",cond);

放入条件列表
condList.add(cond);

4、$gte/$lte/$gt/$lt
接1实例中,要筛选出年龄大于20且小于等于40的用户,我们可以这样:
cond = new BasicDBObject();
cond.append("age",new BasicDBObject("$gt",20));
cond.append("age",new BasicDBObject("$lte",40));

放入条件列表
condList.add(cond);

在日常的查询中筛选的条件可能会有多个,而且多个条件之间都是且的关系,结合上例1、2、3、4中
将每种条件添加到条件列表中,我可以这样:
BasicDBObject searchCond = new BasicDBObject();
searchCond.put("$and", condList);

然后查询数据:
DBCursor ret = coll.find(searchCond);
参考技术A 为什么你里面既有in又有and?根据你的条件貌似一个in就可以了,所以你那个condList根本也就不需要。下面是我写的,你试试,因为没有环境,没有运行过,错了还望抱歉。
BasicDBList cond= new BasicDBList();
cond.add(10);
cond.add(15);
BasicDBObject in = new BasicDBObject("$in", cond);
DBCursor cursor = db.getCollection("test").find(new BasicDBObject("age", in));本回答被提问者和网友采纳

mongodb 查询数组内符合条件的值

db.listdb内有如下内容:
"list":
["num":1, "name":"a",
"num":2, "name":"b",
"num":7, "name":"c",
"num":3, "name":"c",
"num":4, "name":"c" ]
如何能只选出list中num大于3的数组内容呢?
db.listdb.find("list.num": $gt:3); 会返回全部内容,我只想要如下的结果:

"list":
[ "num":7, "name":"c",
"num":4, "name":"c" ]
请问如何能查询出来? 感谢!

参考技术A "list":
["num":1, "name":"a",
"num":2, "name":"b",
"num":7, "name":"c",
"num":3, "name":"c",
"num":4, "name":"c" ]

这样就可以查询出来你要的结果追问

如果我list数组里面有1000条记录,但我只想要返回里面符合条件的几条记录,如果1000条都返回了就没有意义了。

追答

list这样写就可以查询出你要的几条数据,你那种写法怎么查都会出来

参考技术B 总感觉这结构不对啊,你是怎么insert这个数据的追问

list:[],然后push

追答



你这数据结构不对,他们都是list的值了,

追问

结构没有问题的,这个数组就是List,选加入一个空数组给List,然后再把这5个值push到list中

以上是关于java mongodb查询条件的主要内容,如果未能解决你的问题,请参考以下文章

如何使用 mongoDB 条件查询在 java 中获得更干净的代码 [重复]

Java操作mongodb的基本操作

mongoDB在java中怎么根据内嵌文档条件查询

java怎么做到使用mongodb来进行分组查询统

MongoDB批量更新不同查询条件的数据

如何利用spring data mongodb 进行多条件查询