Browse Source

added additional query signatures

pull/1/head
Thomas Risberg 15 years ago
parent
commit
a08f5f3b3a
  1. 22
      src/main/java/org/springframework/datastore/document/mongodb/MongoTemplate.java

22
src/main/java/org/springframework/datastore/document/mongodb/MongoTemplate.java

@ -35,6 +35,7 @@ import com.mongodb.DBCollection;
import com.mongodb.DBObject; import com.mongodb.DBObject;
import com.mongodb.MongoException; import com.mongodb.MongoException;
import com.mongodb.WriteResult; import com.mongodb.WriteResult;
import com.mongodb.util.JSON;
public class MongoTemplate extends AbstractDocumentStoreTemplate<DB> { public class MongoTemplate extends AbstractDocumentStoreTemplate<DB> {
@ -118,15 +119,32 @@ public class MongoTemplate extends AbstractDocumentStoreTemplate<DB> {
if (operands.length != values.length) { if (operands.length != values.length) {
throw new InvalidDocumentStoreApiUageException("The number of operands and values must match"); throw new InvalidDocumentStoreApiUageException("The number of operands and values must match");
} }
List<T> results = new ArrayList<T>();
DBObject query = new BasicDBObject(); DBObject query = new BasicDBObject();
DBObject condition = new BasicDBObject(); DBObject condition = new BasicDBObject();
for (int i = 0; i < operands.length; i++) { for (int i = 0; i < operands.length; i++) {
condition.put(operands[i], values[i]); condition.put(operands[i], values[i]);
} }
query.put(fieldName, condition); query.put(fieldName, condition);
System.out.println("--> " + query); return queryForList(collectionName, query, mapper);
}
public <T> List<T> queryForList(String collectionName, String query, Class<T> targetClass) {
DocumentMapper<DBObject, T> mapper = MongoBeanPropertyDocumentMapper.newInstance(targetClass);
return queryForList(collectionName, query, mapper);
}
public <T> List<T> queryForList(String collectionName, String query, DocumentMapper<DBObject, T> mapper) {
return queryForList(collectionName, (DBObject)JSON.parse(query), mapper);
}
public <T> List<T> queryForList(String collectionName, DBObject query, Class<T> targetClass) {
DocumentMapper<DBObject, T> mapper = MongoBeanPropertyDocumentMapper.newInstance(targetClass);
return queryForList(collectionName, query, mapper);
}
public <T> List<T> queryForList(String collectionName, DBObject query, DocumentMapper<DBObject, T> mapper) {
DBCollection collection = getConnection().getCollection(collectionName); DBCollection collection = getConnection().getCollection(collectionName);
List<T> results = new ArrayList<T>();
for (DBObject dbo : collection.find(query)) { for (DBObject dbo : collection.find(query)) {
results.add(mapper.mapDocument(dbo)); results.add(mapper.mapDocument(dbo));
} }

Loading…
Cancel
Save