szykra/resource-naming-strategy 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

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

szykra/resource-naming-strategy

最新稳定版本:0.1.4

Composer 安装命令:

composer require szykra/resource-naming-strategy

包简介

Resource Naming Strategy for Doctrine ORM

README 文档

README

building codeclimate version license

Resource Naming Strategy for Doctrine ORM

Why Resource?

This naming strategy following the natural way of thinking about entities and resources. Imagine that you have one Flower. It's single entity. You want to store some data about flowers e.g. in your database. It's resource.

Simple? I know resource named flower sounds easier but sometimes it's more confusing. In the end, you have a lot of flowers, not one.

This strategy is similar to the Laravel naming convention (See mapping section).

Requirements

This package uses icanboogie/inflector and it requires a mbstring php extension.

Instalation

Install via composer

Add dependecy to your composer.json file and run composer update.

"require": {
    "szykra/resource-naming-strategy": "~0.1"
}

Usage

Usage with Doctrine

$namingStrategy = new \Szykra\NamingStrategy\ResourceNamingStrategy();
$configuration()->setNamingStrategy($namingStrategy);

Usage with Symfony

You have a two ways to use this naming strategy

Register bundle in AppKernel.php

Just open your AppKernel.php file and register new symfony bundle which contains a service definition.

$bundles = array(
    ...
    new Szykra\NamingStrategy\ResourceNamingBundle\ResourceNamingBundle()
);

Now you can configure Doctrine in config.yml to use new naming strategy.

doctrine:
    orm:
        naming_strategy: szykra.naming_strategy.resource_naming_strategy

Define your own service

If you don't want to register additional bundles you can create own service definiton in services.yml:

services:
    app.naming_strategy.resource:
        class: Szykra\NamingStrategy\ResourceNamingStrategy

And don't forget to configure Doctrine to use this service.

Mapping

Entity to table name

Lowercase and plural

Entity Table
User users
Category categories
TaskActivity task_activities

Property to column name

Lowercase letters and words separated by the underscore

Property Column
firstName first_name
LastName last_name
secondRememberToken second_remember_token

Embedded field to column name

Lowercase letters and words separated by the underscore

Property from embedded Address Column
street address_street
postcode address_postcode
addressLineOne address_address_line_one

Join column name

Lowercase letters and words separated by the underscore with _id suffix

Property Column
reporter reporter_id
task_activity task_activity_id

Join table name

Two singular lowercase entity names in ascending order with words separated by the underscore

Entity 1 Entity 2 Table
User Task task_user
Comment Post comment_post
Work TimeLog time_log_work

License

The MIT License. Copyright © 2015 - 2020 Szymon Krajewski.

统计信息

  • 总下载量: 23.23k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 4
  • 点击次数: 1
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2015-04-30