承接 koriym/csv-entities 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

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.

Japanese

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

GitHub 信息

  • Stars: 2
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2023-05-14