承接 roukmoute/doctrine-prefix-bundle 相关项目开发

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

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

roukmoute/doctrine-prefix-bundle

最新稳定版本:v2.0.0

Composer 安装命令:

composer require roukmoute/doctrine-prefix-bundle

包简介

Listener that prefixes tables and sequences

README 文档

README

CI

A Symfony bundle that automatically prefixes Doctrine ORM table names, indexes, unique constraints, and PostgreSQL sequences.

Prefixes are useful when you need to:

  • Share a database with tables from another project
  • Use reserved SQL keywords as entity names (like user or group)
  • Organize tables by application or module

Requirements

  • PHP ^8.1
  • Symfony ^6.4 || ^7.0
  • Doctrine ORM ^3.0

Installation

composer require roukmoute/doctrine-prefix-bundle

With Symfony Flex, the bundle is automatically registered.

Configuration

# config/packages/roukmoute_doctrine_prefix.yaml
roukmoute_doctrine_prefix:
    prefix: 'app_'

Options

Option Type Default Description
prefix string '' The prefix to prepend to names
bundles array [] If set, only entities from these namespaces will be prefixed
encoding string 'UTF-8' The encoding for the prefix

Example with bundle filtering

roukmoute_doctrine_prefix:
    prefix: 'app_'
    bundles:
        - 'App\Entity'
        - 'Acme\BlogBundle\Entity'

What gets prefixed?

Element Example (prefix: app_)
Table names userapp_user
Index names idx_emailapp_idx_email
Unique constraint names uniq_emailapp_uniq_email
Many-to-many join tables user_roleapp_user_role
PostgreSQL sequences user_id_seqapp_user_id_seq

Example

use Doctrine\ORM\Mapping as ORM;

#[ORM\Entity]
#[ORM\Table(
    indexes: [new ORM\Index(name: 'idx_email', columns: ['email'])],
    uniqueConstraints: [new ORM\UniqueConstraint(name: 'uniq_username', columns: ['username'])]
)]
class User
{
    #[ORM\Id]
    #[ORM\GeneratedValue]
    #[ORM\Column]
    private ?int $id = null;

    #[ORM\Column(length: 180)]
    private ?string $email = null;

    #[ORM\Column(length: 50)]
    private ?string $username = null;

    #[ORM\ManyToMany(targetEntity: Role::class)]
    private Collection $roles;
}

With prefix: 'app_', this will generate:

  • Table: app_user
  • Index: app_idx_email
  • Unique constraint: app_uniq_username
  • Join table: app_user_role

License

MIT

统计信息

  • 总下载量: 19.4k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 3
  • 点击次数: 2
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 3
  • Watchers: 1
  • Forks: 1
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2014-09-29

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固