ecommit/doctrine-orm-refetch
最新稳定版本:v1.1.1
Composer 安装命令:
composer require ecommit/doctrine-orm-refetch
包简介
Refetch ORM Doctrine objects. Or detach all entities attached since a snapshot
README 文档
README
This library allows to
- re-fetch Doctrine ORM objects after clear the object manager
- detach all entities attached since a snapshot
Installation
To install doctrine-orm-refetch with Composer just run :
$ composer require ecommit/doctrine-orm-refetch
Usage
Create the utility ($entityManager is the Doctrine ORM entity manager):
use Ecommit\DoctrineOrmRefetch\RefetchManager; $refetchManager = RefetchManager::create($entityManager);
Refetch an object
$myObject = $refetchManager->getFetchedObject($myObject); //or $refetchManager->refreshObject($myObject);
Example:
use Ecommit\DoctrineOrmRefetch\RefetchManager; $refetchManager = RefetchManager::create($entityManager); $author = $entityManager->getRepository(Author::class)->find(1); $queryBuilder = $entityManager->getRepository(Book::class)->createQueryBuilder('b'); $queryBuilder->select('b') ->andWhere('b.bookId != :bookId') ->setParameter('bookId', 7); $iterableResult = $queryBuilder->getQuery()->iterate(); $i = 0; foreach ($iterableResult as $row) { ++$i; $book = current($row); if (!$book->getAuthors()->contains($author)) { $book->addAuthor($author); } if (0 === $i % 20) { //$author is managed $entityManager->flush(); $entityManager->clear(); //$author is not managed $author = $refetchManager->getObject($author); //$author is managed } } $entityManager->flush(); $entityManager->clear();
Get collection by critera
$collection = $refetchManager->getCollectionFromCriteria($criteria, 'MyClass');
Example:
use Doctrine\Common\Collections\Criteria; use Ecommit\DoctrineOrmRefetch\RefetchManager; $refetchManager = RefetchManager::create($entityManager); $ctiteria = Criteria::create() ->andWhere(Criteria::expr()->gt('authorId', 2)); $authors = $refetchManager->getCollectionFromCriteria($ctiteria, Author::class); $queryBuilder = $entityManager->getRepository(Book::class)->createQueryBuilder('b'); $queryBuilder->select('b') ->andWhere('b.bookId != :bookId') ->setParameter('bookId', 9); $iterableResult = $queryBuilder->getQuery()->iterate(); $i = 0; foreach ($iterableResult as $row) { ++$i; $book = current($row); foreach ($authors as $author) { if (!$book->getAuthors()->contains($author)) { $book->addAuthor($author); } } if (0 === $i % 20) { $entityManager->flush(); $entityManager->clear(); $authors = $refetchManager->getCollectionFromCriteria($ctiteria, Author::class); } } $entityManager->flush(); $entityManager->clear();
Snapshot
Detach all entities attached since a snapshot (entities attached before the snapshot are kept)
use Ecommit\DoctrineOrmRefetch\SnapshotManager; $snapshotManager = SnapshotManager::create($entityManager); $author = $entityManager->getRepository(Author::class)->find(1); $snapshotManager->snapshot(); $queryBuilder = $entityManager->getRepository(Book::class)->createQueryBuilder('b'); $queryBuilder->select('b') ->andWhere('b.bookId != :bookId') ->setParameter('bookId', 7); $iterableResult = $queryBuilder->getQuery()->iterate(); $i = 0; foreach ($iterableResult as $row) { ++$i; /** @var Book $book */ $book = current($row); if (!$book->getAuthors()->contains($author)) { $book->addAuthor($author); } if (0 === $i % 2) { // $author and $book are managed $entityManager->flush(); $snapshotManager->clear(); // Detach all entities attached since the snapshot // Only $author is managed } } $entityManager->flush(); $snapshotManager->clear();
License
This librairy is under the MIT license. See the complete license in LICENSE file.
统计信息
- 总下载量: 3.43k
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 1
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2020-02-11