當前位置: 首頁>>代碼示例>>Java>>正文


Java DBCursor.limit方法代碼示例

本文整理匯總了Java中com.mongodb.DBCursor.limit方法的典型用法代碼示例。如果您正苦於以下問題:Java DBCursor.limit方法的具體用法?Java DBCursor.limit怎麽用?Java DBCursor.limit使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在com.mongodb.DBCursor的用法示例。


在下文中一共展示了DBCursor.limit方法的14個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: testRetrieveAllAssetsPaginated

import com.mongodb.DBCursor; //導入方法依賴的package包/類
/**
 * Test that providing a PaginationOptions object results in the correct skip() and limit()
 * methods being called on the result cursor.
 */
@Test
public void testRetrieveAllAssetsPaginated(final @Mocked DBCollection collection, final @Injectable DBCursor cursor) {

    new Expectations() {
        {

            collection.find((DBObject) withNotNull(), (DBObject) withNull());
            result = cursor;
            cursor.skip(20);
            cursor.limit(10);
        }
    };

    List<AssetFilter> filters = new ArrayList<>();
    filters.add(new AssetFilter("key1", Arrays.asList(new Condition[] { new Condition(Operation.EQUALS, "value1") })));
    PaginationOptions pagination = new PaginationOptions(20, 10);
    createTestBean().retrieveAllAssets(filters, null, pagination, null);
}
 
開發者ID:WASdev,項目名稱:tool.lars,代碼行數:23,代碼來源:PersistenceBeanBasicSearchTest.java

示例2: getChatMessages

import com.mongodb.DBCursor; //導入方法依賴的package包/類
/**
 * @param channelId The Unique ID of the channel.
 * @param limit     The Integer limit of ChatMessages to load.
 * @return Returns a List of ChatMessages for the ChatChannel.
 */
private List<ChatMessage> getChatMessages(UUID channelId, int limit) {
    List<ChatMessage> listChatMessages = new LinkedList<>();
    // Grab all the messages with the channel_id set to the one provided.
    DBObject query = new BasicDBObject("channel_id", channelId);
    DBCursor cursor = collectionMessages.find(query);
    // Sort the list by timestamp so that the last messages appear first.
    cursor.sort(new BasicDBObject("timestamp", -1));
    cursor.limit(limit);
    if(cursor.size() > 0) {
        List<DBObject> listObjects = cursor.toArray();
        Collections.reverse(listObjects);
        for(DBObject object : listObjects) {
            // Create the MongoDocument.
            MongoChatMessage mongoChatMessage = new MongoChatMessage(collectionMessages, object);
            // Create the container for the document.
            ChatMessage chatMessage = new ChatMessage(mongoChatMessage);
            // Add this to the list to return.
            listChatMessages.add(chatMessage);
        }
    }
    // Close the cursor to release resources.
    cursor.close();
    // Return the result list of messages for the channel.
    return listChatMessages;
}
 
開發者ID:JabJabJab,項目名稱:Sledgehammer,代碼行數:31,代碼來源:ModuleChat.java

示例3: getRecentBuildStatsForProduct

import com.mongodb.DBCursor; //導入方法依賴的package包/類
@GET
@Path("/recent-builds/{product}")
public DBObject getRecentBuildStatsForProduct(@BeanParam final Coordinates coordinates, @QueryParam("limit") final Integer limit) {
	final BasicDBList returns = new BasicDBList();
	final DB db = this.client.getDB("bdd");
	final DBCollection collection = db.getCollection("reportStats");
	final BasicDBObject example = coordinates.getQueryObject(Field.PRODUCT);
	final DBCursor cursor = collection.find(example).sort(Coordinates.getFeatureSortingObject());
	if (limit != null) {
		cursor.limit(limit);
	}
	try {
		while (cursor.hasNext()) {
			final DBObject doc = cursor.next();
			returns.add(doc);
		}
	} finally {
		cursor.close();
	}
	return returns;
}
 
開發者ID:orionhealth,項目名稱:XBDD,代碼行數:22,代碼來源:AutomationStatistics.java

示例4: selectSet

import com.mongodb.DBCursor; //導入方法依賴的package包/類
public DBCursor selectSet(DBCollection collection) {
	DBObject fields = getFields();
	DBObject query = getQuery();
	DBObject orderByObject = getOrderByObject();
	DBCursor cursor = null;

	// 日誌
	log(fields, query, orderByObject);

	if (null != query && null == fields) {
		cursor = collection.find(query);
	} else if (null == query && null != fields) {
		cursor = collection.find(new BasicDBObject(), fields);
	} else if (null != fields && null != query) {
		cursor = collection.find(query, fields);
	} else {
		cursor = collection.find();
	}

	if (null != orderByObject) {
		cursor.sort(orderByObject);
	}
	if (null != this.limit) {
		if (null == this.limit.getOffset()) {
			cursor.limit(this.limit.getRowCount());
		} else {
			cursor.limit(this.limit.getRowCount());
			cursor.skip(this.limit.getOffset());
		}
	}
	return cursor;
}
 
開發者ID:xsonorg,項目名稱:tangyuan2,代碼行數:33,代碼來源:SelectVo.java

示例5: find

import com.mongodb.DBCursor; //導入方法依賴的package包/類
private static ModulesContainer find(DBObject query, DBObject orderBy, Integer limit, Integer page) throws SinfonierException {
  DBCollection collection = MongoFactory.getDB().getCollection(collectionName);
  List<Module> list = new ArrayList<Module>();
  DBCursor cursor;
  
  if (limit != null) {
    page = (page != null && page > 0) ? ((page-1)*limit) : 0;
  } else {
    page = null;
  }

  if (query == null) {
    cursor = collection.find();
  } else {
    cursor = collection.find(query);
  }

  int totalModules = cursor.count();
  
  if (orderBy != null) {
    cursor = cursor.sort(orderBy);
  }
  
  if (page != null && page > 0) {
    cursor.skip(page);
  }
  
  if (limit != null) {
    cursor = cursor.limit(limit);
  }

  for (DBObject dbObject : cursor) {
    list.add(new Module(dbObject));
  }

  return new ModulesContainer(list, totalModules);
}
 
開發者ID:telefonicaid,項目名稱:fiware-sinfonier,代碼行數:38,代碼來源:Module.java

示例6: find

import com.mongodb.DBCursor; //導入方法依賴的package包/類
private static TopologiesContainer find(DBObject query, DBObject orderBy, Integer limit, Integer page) throws SinfonierException {
  DBCollection collection = MongoFactory.getDB().getCollection(getCollectionName());
  List<Topology> list = new ArrayList<Topology>();
  DBCursor cursor;

  if (limit != null) {
    page = (page != null && page > 0) ? ((page-1)*limit) : 0;
  } else {
    page = null;
  }
  
  if (query == null) {
    cursor = collection.find();
  } else {
    cursor = collection.find(query);
  }
  
  int totalTopologies = cursor.count();

  if (orderBy != null) {
    cursor = cursor.sort(orderBy);
  }

  if (page != null && page > 0) {
    cursor.skip(page);
  }
  
  if (limit != null) {
    cursor = cursor.limit(limit);
  }

  for (DBObject dbObject : cursor) {
    list.add(new Topology(dbObject));
  }

  return new TopologiesContainer(list, totalTopologies);
}
 
開發者ID:telefonicaid,項目名稱:fiware-sinfonier,代碼行數:38,代碼來源:Topology.java

示例7: getFeatures

import com.mongodb.DBCursor; //導入方法依賴的package包/類
/**
 *
 * @param queryObject
 * @param limit Limitation on the number of results returned. Setting to 0 is equivalent to unlimited
 * @return
 * @throws IOException
 */
private Collection<DBFeature.IGVFeat> getFeatures(DBObject queryObject, int limit) throws IOException{
    DBCursor cursor = this.collection.find(queryObject);
    cursor.limit(limit >= 0 ? limit : 0);

    //Sort by increasing start value
    //Only do this if we have an index, otherwise might be too memory intensive
    if(hasLocusIndex){
        cursor.sort(new BasicDBObject("Start", 1));
    }
    boolean isSorted = true;
    int lastStart = -1;

    List<DBFeature.IGVFeat> features = new ArrayList<DBFeature.IGVFeat>();
    while (cursor.hasNext()) {
        DBObject obj = cursor.next();
        DBFeature feat = (DBFeature) obj;
        features.add(feat.createIGVFeature());
        isSorted &= feat.getStart() >= lastStart;
        lastStart = feat.getStart();
    }

    if(!isSorted){
        FeatureUtils.sortFeatureList(features);
    }

    return features;
}
 
開發者ID:hyounesy,項目名稱:ALEA,代碼行數:35,代碼來源:MongoFeatureSource.java

示例8: getRecentVersionStatsForProduct

import com.mongodb.DBCursor; //導入方法依賴的package包/類
/**
 * Go through the prior versions of this product; for each version, find the latest build and contribute the stats for that to the
 * returned list.
 *
 * @param coordinates
 * @param limit
 * @return A list of report stats in reverse version order.
 * @throws UnknownHostException
 */
@GET
@Path("/recent-versions/{product}")
public DBObject getRecentVersionStatsForProduct(@BeanParam final Coordinates coordinates, @QueryParam("limit") final Integer limit) {
	final BasicDBList returns = new BasicDBList();

	final DB db = this.client.getDB("bdd");
	final DBCollection summaryCollection = db.getCollection("summary");
	final DBCollection reportStatsCollection = db.getCollection("reportStats");
	final DBCursor versions = summaryCollection.find(coordinates.getQueryObject(Field.PRODUCT)).sort(Coordinates.getFeatureSortingObject());
	if (limit != null) {
		versions.limit(limit);
	}
	try {
		while (versions.hasNext()) { // go through each summary document
			final DBObject version = versions.next(); // each represents the coordinates for a given version
			final Coordinates c = new Coordinates((DBObject) version.get("coordinates"));
			final BasicDBList builds = (BasicDBList) version.get("builds");
			c.setBuild((String) builds.get(builds.size() - 1)); // we need to specify which build (the latest is last in the list)
			final DBObject query = c.getQueryObject();
			returns.add(reportStatsCollection.findOne(query));
		}
	} finally {
		versions.close();
	}

	return returns;
}
 
開發者ID:orionhealth,項目名稱:XBDD,代碼行數:37,代碼來源:AutomationStatistics.java

示例9: getReportByProductVersionId

import com.mongodb.DBCursor; //導入方法依賴的package包/類
@GET
@Path("/{product}/{major}.{minor}.{servicePack}/{build}")
@Produces("application/json")
public DBObject getReportByProductVersionId(@BeanParam final Coordinates coordinates,
		@QueryParam("searchText") final String searchText, @QueryParam("viewPassed") final Integer viewPassed,
		@QueryParam("viewFailed") final Integer viewFailed,
		@QueryParam("viewUndefined") final Integer viewUndefined, @QueryParam("viewSkipped") final Integer viewSkipped,
		@QueryParam("start") final String start, @QueryParam("limit") final Integer limit) {

	final BasicDBObject example = QueryBuilder.getInstance().buildFilterQuery(coordinates, searchText, viewPassed,
			viewFailed, viewUndefined, viewSkipped, start);

	final DB db = this.client.getDB("bdd");
	final DBCollection collection = db.getCollection("features");
	final DBCursor cursor = collection.find(example).sort(Coordinates.getFeatureSortingObject());
	try {
		if (limit != null) {
			cursor.limit(limit);
		}
		final BasicDBList featuresToReturn = new BasicDBList();
		while (cursor.hasNext()) {
			featuresToReturn.add(cursor.next());
		}
		embedTestingTips(featuresToReturn, coordinates, db);
		return featuresToReturn;
	} finally {
		cursor.close();
	}
}
 
開發者ID:orionhealth,項目名稱:XBDD,代碼行數:30,代碼來源:Report.java

示例10: query

import com.mongodb.DBCursor; //導入方法依賴的package包/類
private AssetCursor query(DBObject filterObject, DBObject sortObject, DBObject projectionObject, PaginationOptions pagination) {

        if (logger.isLoggable(Level.FINE)) {
            logger.fine("query: Querying database with query object " + filterObject);
            logger.fine("query: sort object " + sortObject);
            logger.fine("query: projection object " + projectionObject);
            logger.fine("query: pagination object " + pagination);
        }

        DBCursor cursor = getAssetCollection().find(filterObject, projectionObject);
        if (logger.isLoggable(Level.FINE)) {
            logger.fine("query: found " + cursor.count() + " assets.");
        }

        if (pagination != null) {
            cursor.skip(pagination.getOffset());
            cursor.limit(pagination.getLimit());
        }

        if (sortObject != null) {
            cursor.sort(sortObject);
        }

        AssetCursor result = new MongoAssetCursor(cursor);
        result.addOperation(CONVERT_OID_TO_HEX);

        return result;
    }
 
開發者ID:WASdev,項目名稱:tool.lars,代碼行數:29,代碼來源:PersistenceBean.java

示例11: addOptionsOn

import com.mongodb.DBCursor; //導入方法依賴的package包/類
private void addOptionsOn(DBCursor cursor) {
    if (limit != null) {
        cursor.limit(limit);
    }
    if (skip != null) {
        cursor.skip(skip);
    }
    if (sort != null) {
        cursor.sort(sort.toDBObject());
    }
    if (hint != null) {
        cursor.hint(hint.toDBObject());
    }
}
 
開發者ID:CIDARLAB,項目名稱:clotho3crud,代碼行數:15,代碼來源:RefFind.java

示例12: applyCursorConfigs

import com.mongodb.DBCursor; //導入方法依賴的package包/類
public void applyCursorConfigs(DBCursor dbCursor) {
  if (skip!=null || limit!=null) {
    log.debug("Applying page to cursor: skip="+skip+", limit="+limit);
    if (skip!=null) {
      dbCursor.skip(skip);
    }
    if (limit!=null) {
      dbCursor.limit(limit);
    }
  }
  if (orderBy!=null) {
    log.debug("Applying sort to cursor: "+orderBy);
    dbCursor.sort(orderBy);
  }
}
 
開發者ID:effektif,項目名稱:effektif,代碼行數:16,代碼來源:Query.java

示例13: createWorkflowDbCursor

import com.mongodb.DBCursor; //導入方法依賴的package包/類
public DBCursor createWorkflowDbCursor(WorkflowQuery query) {
  BasicDBObject dbQuery = createDbQuery(query);
  DBCursor dbCursor = workflowsCollection.find("find-workflows", dbQuery);
  if (query.getLimit()!=null) {
    dbCursor.limit(query.getLimit());
  }
  if (query.getOrderBy()!=null) {
    dbCursor.sort(writeOrderBy(query.getOrderBy()));
  }
  return dbCursor;
}
 
開發者ID:effektif,項目名稱:effektif,代碼行數:12,代碼來源:MongoWorkflowStore.java

示例14: findData

import com.mongodb.DBCursor; //導入方法依賴的package包/類
@Override
public <T extends Model> List<Map<String, Object>> findData(Class<T> modelClass, Map<String, Object> filter,
    QueryOptions queryOptions, DBCollection collection) {
    if (modelClass == null)
        throw new DaoException("Model class cannot be empty");

    if (filter == null)
        filter = EMPTY_FILTER;

    List<Map<String, Object>> docs = new ArrayList<>();

    DBObject dbObject = buildQueryFilter(modelClass, filter, queryOptions);

    // if (!modelClass.getName().startsWith("com.geecommerce.core"))
    // System.out.println("filter: " + dbObject);

    DBObject fields = buildFieldList(modelClass, queryOptions);
    // System.out.println("fields: " + fields);

    DBObject sortBy = buildSortBy(modelClass, queryOptions);
    // System.out.println("sort: " + sortBy);

    DBCollection col = collection == null ? collection(modelClass) : collection;

    // ------------------------------------------------------------------
    // Query with filter
    // ------------------------------------------------------------------

    DBCursor cursor = null;

    try {
        cursor = col.find(dbObject, fields);
        cursor.sort(sortBy);

        if (queryOptions != null && queryOptions.limit() != null) {
            cursor.limit(queryOptions.limit());
        } else {
            // There is no reason to ever return more than 1500 results. //
            // TODO: make configurable
            cursor.limit(1500);
        }

        if (queryOptions != null && queryOptions.offset() != null) {
            cursor.skip(queryOptions.offset().intValue());
        }

        // ------------------------------------------------------------------
        // Iterate through results and add to results list docs
        // ------------------------------------------------------------------
        while (cursor.hasNext()) {
            DBObject doc = cursor.next();

            if (doc != null) {
                try {
                    Map<String, Object> map = new LinkedHashMap<>();
                    convertToMongoDBValues(doc, map);

                    docs.add(map);
                } catch (Throwable t) {
                    t.printStackTrace();
                    throw new DaoException(t);
                }
            }
        }
    } finally {
        if (cursor != null)
            cursor.close();
    }

    return docs;
}
 
開發者ID:geetools,項目名稱:geeCommerce-Java-Shop-Software-and-PIM,代碼行數:72,代碼來源:AbstractMongoDao.java


注:本文中的com.mongodb.DBCursor.limit方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。