MongoDB
 sql >> база данни >  >> NoSQL >> MongoDB

Посочете множество критерии в spring mongo db заявка

Можете да преработите кода си, за да създадете $or изрази. Без изричен $and необходим е оператор.

Нещо като

 Query orQuery = new Query();
 Criteria orCriteria = new Criteria();
 List<Criteria> orExpression =  new ArrayList<>();
 for (Map<String, Object> accounts : attributes) {
   Criteria expression = new Criteria();
   accounts.forEach((key, value) -> expression.and(key).is(value));
   orExpression.add(expression);
 }
 orQuery.addCriteria(orCriteria.orOperator(orExpression.toArray(new Criteria[orExpression.size()])));
 List<User> userList = mongoOperations.find(orQuery, User.class);

Това трябва да изведе заявка като

{ "$or" : [{ "key1" : "value1", "key2" : "value2" }, { "key3" : "value3", "key4" : "value4" }] }


  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Отношения на MongoDB:вграждане или справка?

  2. MongoDB - upsert, включващ списъци

  3. Как обработваме приоритета на заявките в express/nodejs?

  4. NodeJS излиза от всички потребителски сесии

  5. Как кажете на Mongo да сортира колекция, преди да ограничи резултатите?