本文整理匯總了PHP中Doctrine\Common\Collections\Criteria::setFirstResult方法的典型用法代碼示例。如果您正苦於以下問題:PHP Criteria::setFirstResult方法的具體用法?PHP Criteria::setFirstResult怎麽用?PHP Criteria::setFirstResult使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類Doctrine\Common\Collections\Criteria
的用法示例。
在下文中一共展示了Criteria::setFirstResult方法的13個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。
示例1: createCriteria
private function createCriteria()
{
$criteria = new Criteria();
$criteria->orderBy(array('username' => 'ASC'));
$criteria->setFirstResult(2);
$criteria->setMaxResults(3);
return $criteria;
}
示例2: initDatabaseMock
/**
* Initialize mocks for Doctrine
*
* @param array $managersToMock List of managers to be mocked
*
* @return void
*/
protected function initDatabaseMock($managersToMock)
{
if (is_null($this->mockedManager)) {
$test = $this;
foreach ($managersToMock as $manager) {
$entityName = $manager['entityName'];
// EntityManager mock
$entityManagerMock = new \mock\Doctrine\ORM\EntityManager();
// ClassMetadata mock
$classMetadata = new \mock\Doctrine\ORM\Mapping\ClassMetadata($entityName);
$entityClassName = $manager['entityClassName'];
$this->calling($classMetadata)->getName = function () use($entityClassName) {
return $entityClassName;
};
// EntityRepository mock
$entityRepositoryMock = new \mock\Doctrine\ORM\EntityRepository($entityManagerMock, $classMetadata);
$this->calling($entityRepositoryMock)->find = function ($id) use($test, $entityName) {
if (!empty($test->database[$entityName]) && array_key_exists($id, $test->database[$entityName])) {
return clone $test->database[$entityName][$id];
}
return null;
};
$this->calling($entityRepositoryMock)->findBy = function ($criteria = [], $sort = null, $limit = null, $start = 0) use($test, $entityName) {
$entities = new ArrayCollection($test->database[$entityName]);
$crit = new Criteria();
foreach ($criteria as $field => $value) {
$crit->andWhere($crit->expr()->eq($field, $value));
}
if (!is_null($sort)) {
$crit->orderBy($sort);
}
$crit->setFirstResult($start);
$crit->setMaxResults($limit);
return $entities->matching($crit)->map(function ($item) {
return clone $item;
});
};
// Overload main EntityManager functions
$this->calling($entityManagerMock)->getRepository = function () use($entityRepositoryMock) {
return $entityRepositoryMock;
};
$this->calling($entityManagerMock)->getClassMetadata = function ($entity) use($classMetadata) {
return $classMetadata;
};
$this->calling($entityManagerMock)->persist = function ($entity) use($test, $entityName) {
if (!$entity->getId()) {
if (!empty($test->database[$entityName])) {
$entity->setId(count($test->database[$entityName]) + 1);
} else {
$entity->setId(1);
}
}
$test->database[$entityName][$entity->getId()] = $entity;
return true;
};
$this->calling($entityManagerMock)->remove = function ($entity) use($test, $entityName) {
if (!$entity->getId() || empty($test->database[$entityName][$entity->getId()])) {
return false;
}
unset($test->database[$entityName][$entity->getId()]);
return true;
};
$mockClass = '\\mock' . $manager['className'];
$managerMock = new $mockClass($entityManagerMock, $entityName);
$this->mockedManager[$manager['serviceName']] = $managerMock;
}
}
}
示例3: getItems
/**
* Get items
* @author Mohamed Labib <mohamed.labib@camelcasetech.com>
*
* @access public
*
* @param int $offset
* @param int $itemCountPerPage
* @return array items queried
*/
public function getItems($offset, $itemCountPerPage)
{
$this->setCriteria();
$this->criteria->setFirstResult($offset);
$this->criteria->setMaxResults($itemCountPerPage);
return $this->query->filter($this->entityName, $this->criteria);
//($pageNumber-1) for zero based count
}
示例4: execute
protected function execute(InputInterface $input, OutputInterface $output)
{
$indexName = $input->getOption('index');
$batchSize = $input->getOption('batch_size');
$indexManager = $this->getIndexManager($indexName);
$totalDocuments = $indexManager->getTotalEntities();
$iterations = $this->getIterations($totalDocuments, $batchSize);
$output->writeln(sprintf('<info>Reindexing</info> "%s"', $indexName));
$output->writeln(sprintf('<comment>Total documents:</comment> %s', $totalDocuments));
$output->writeln(sprintf('<comment>Batch size:</comment> %s', $batchSize));
$output->writeln(sprintf('<comment>Iterations:</comment> %s', $iterations));
$progress = new ProgressBar($output, $totalDocuments);
$progress->setFormat('verbose');
$progress->setRedrawFrequency($batchSize);
$progress->start();
$indexManager->purgeIndex();
for ($i = 0; $i < $iterations; $i++) {
$criteria = new Criteria();
$criteria->setMaxResults($batchSize);
$criteria->setFirstResult($i * $batchSize);
$collection = $indexManager->getEntitiesCollection($criteria);
$collection->map(function (EntityInterface $entity) use($indexManager, $progress) {
$indexManager->addEntity($entity);
$progress->advance();
});
}
$progress->finish();
$output->writeln('');
$output->writeln(sprintf('<info>Optimizing "%s"</info>', $indexName));
$indexManager->optimizeIndex();
}
示例5: apply
/**
* {@inheritdoc}
*/
public function apply(Criteria $criteria, FilterValue $value = null)
{
$val = null !== $value ? $value->getValue() : $this->getDefaultValue();
if (null !== $val) {
$pageSize = $criteria->getMaxResults();
if (null !== $pageSize) {
$criteria->setFirstResult(QueryUtils::getPageOffset($val, $pageSize));
}
}
}
示例6: getData
/**
* {@inheritdoc}
*/
public function getData(RequestInterface $request)
{
$criteria = new Criteria();
$criteria->setMaxResults($request->getLimit());
$criteria->setFirstResult($request->getOffset());
$this->processOrder($criteria, $request);
$this->processSearch($criteria, $request);
$this->processGlobalSearch($criteria, $request);
$result = $this->collection->matching($criteria);
return $this->processData($result);
}
示例7: findAllPublic
public function findAllPublic($page, $itemPerPage)
{
$criteria = new Criteria();
$criteria->where($criteria->expr()->eq('r.published', true));
$criteria->orderBy(['r.dateUpdated' => 'DESC']);
$criteria->setFirstResult(($page - 1) * $itemPerPage);
$criteria->setMaxResults($itemPerPage);
/** @var QueryBuilder $queryBuilder */
$queryBuilder = $this->objectRepository->createQueryBuilder('r');
$queryBuilder->addCriteria($criteria);
return new Paginator($queryBuilder);
}
示例8: limit
/**
* Apply limit and offset on data
* @param int $offset
* @param int $limit
* @return static
*/
public function limit($offset, $limit)
{
$this->criteria->setFirstResult($offset)->setMaxResults($limit);
return $this;
}
示例9: testAddCriteriaLimit
public function testAddCriteriaLimit()
{
$qb = $this->_em->createQueryBuilder();
$criteria = new Criteria();
$criteria->setFirstResult(2);
$criteria->setMaxResults(10);
$qb->addCriteria($criteria);
$this->assertEquals(2, $qb->getFirstResult());
$this->assertEquals(10, $qb->getMaxResults());
}
示例10: offset
/**
* @param integer $offset
*
* @return mixed
*/
public function offset($offset)
{
$this->criteria->setFirstResult($offset);
}
示例11: getItems
/**
* {@inheritDoc}
*/
public function getItems($offset, $itemCountPerPage)
{
$this->criteria->setFirstResult($offset)->setMaxResults($itemCountPerPage);
return $this->selectable->matching($this->criteria)->toArray();
}
示例12: setFirstResult
/**
* @param int $firstResult
* @return $this
*/
public function setFirstResult($firstResult)
{
$this->criteria->setFirstResult($firstResult);
return $this;
}
示例13: testAddCriteriaLimit
public function testAddCriteriaLimit()
{
$qb = $this->_em->createQueryBuilder();
$qb->select('u')->from('Doctrine\\Tests\\Models\\CMS\\CmsUser', 'u');
$criteria = new Criteria();
$criteria->setFirstResult(2);
$criteria->setMaxResults(10);
$qb->addCriteria($criteria);
$this->assertEquals(2, $qb->getFirstResult());
$this->assertEquals(10, $qb->getMaxResults());
}