grifix/entity-manager
Composer 安装命令:
composer require grifix/entity-manager
包简介
Entity manager with optimistic locking
README 文档
README
When we use the CQRS pattern, we usually don't need all this stuff that classical ORM provides. We don't need relations, criteria, lazy loading etc. We only need to add aggregate and get aggregate from the repository. This library provides this simple functionality, and it also provides upcasting entity structure using the Grifix Normalizer library. It also provides the optimistic lock to resolve the concurrency issue.
Installation
composer require grifix/entity-manager
Usage
Imagine that we have the class Person and we want to store it to the database:
final class Person
{
public function __construct(
public readonly string $id,
public string $firstName,
public string $lastName
) {
}
}
Create a table with the following structure:
create table persons
(
id uuid constraint persons_pk primary key,
version bigint not null,
data jsonb not null
);
Create entity manager:
$dbConnection = \Doctrine\DBAL\DriverManager::getConnection(
[
'dbname' => 'dbname',
'user' => 'user',
'password' => 'password',
'host' => 'host',
'driver' => 'pdo_pgsql'
],
);
$entityManager = \Grifix\EntityManager\EntityManager::create($dbConnection);
Register the Person entity type:
$entityManager->registerEntityType(
'person',
Person::class,
'persons',
[
Schema::create()
->withStringProperty('id')
->withStringProperty('firstName')
->withStringProperty('lastName')
]
);
now you cane store the person to the database:
$person = new Person(
'46acc317-3d11-4aa5-b306-4d6a88f57378',
'John',
'Connor'
);
$this->entityManager->add($person, '46acc317-3d11-4aa5-b306-4d6a88f57378');
$this->entityManager->flush();
and you can get it from the database:
$person = $this->entityManager->get(Person::class, '46acc317-3d11-4aa5-b306-4d6a88f57378');
Entity data structure upcasting
Injecting dependencies inside entity
统计信息
- 总下载量: 163
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 2
- 依赖项目数: 2
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2022-07-28