koriym/csv-entities
最新稳定版本:1.0.2
Composer 安装命令:
composer require koriym/csv-entities
包简介
A PDO mapping library that simplifies fetching and handling of one-to-many relationships
README 文档
README
Efficiently manage one-to-many relationships in PDO with Koriym.CsvEntities. This library simplifies the process of fetching related tables by transforming the results into easily manageable PHP entities. Ideal for scenarios where a primary entity has multiple related sub-entities, it streamlines data handling and reduces the complexity of your code.
PDO - Fetching one to many related tables together
Create a one-to-many entity list with Todo having multiple Memos in PDO as shown below.
Example
SELECT todo.id AS id, todo.title AS title, memo.id AS memo_id, memo.body AS memo_body FROM todo LEFT OUTER JOIN memo ON memo.todo_id = todo.id GROUP BY todo.id;
Memo class
final class Memo { public string $id, public string $title }
Todo class
final class Todo { public string $id, public string $title, /** @var array<Memo> */ public array $memos, }
Usage
Change the above SQL and entity classes as follows.
SELECT todo.id AS id, todo.title AS title, GROUP_CONCAT(memo.id), GROUP_CONCAT(memo.body) FROM todo LEFT OUTER JOIN memo ON memo.todo_id = todo.id GROUP BY todo.id;
final class Memo { public function __construct( public string $id, public string $title ){} }
final class Todo { /** @var array<Memo> */ public array $memos; public function __construct( public string $id, public string $title, string|null $memoIds, string|null $memoBodies ){ $this->memos = (new CsvEntities())(Memo::class, $memoIds, $memoBodies); } }
After query() SQL, fetchAll as follows.
$todoList = $pdo->fetchAll(PDO::FETCH_FUNC, static function (...$args) { return new Todo(...$args); });
We get the Todo[] array we originally intended.
final class Todo { public string $id, public string $title, /** @var array<Memo> */ public array $memos, }
Separator can be specified。
$this->memos = (new CsvEntities())->get("\t", Memo::class, $memoIds, $memoBodies); // tab separator
Set maximum concatenation value for GROUP_CONCAT
The maximum value of the concatenation process of columns using GROUP_CONCAT must be changed to group_concat_max_len in an ini file or query. (default value is 1024)
SET SESSION group_concat_max_len = 200000;
Install
composer require koriym/csv-entities
统计信息
- 总下载量: 75.58k
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 2
- 点击次数: 1
- 依赖项目数: 1
- 推荐数: 1
其他信息
- 授权协议: MIT
- 更新时间: 2023-05-14