承接 tbn/query-builder-repository-generator-bundle 相关项目开发

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

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

tbn/query-builder-repository-generator-bundle

最新稳定版本:2.2.0

Composer 安装命令:

composer require tbn/query-builder-repository-generator-bundle

包简介

Generate filters for queryBuilder in a repository

README 文档

README

The QueryBuilderRepositoryGeneratorBundle generates Repositories in the repository folders

The functions allow to filter on the columns of the entity with a query builder.

See the create queries section for an example.

Installation

Import the bundle using composer

composer require --dev "tbn/query-builder-repository-generator-bundle"

Import the bundle in your AppKernel

if ('dev' === $this->getEnvironment()) {
    $bundles[] = new Tbn\QueryBuilderRepositoryGeneratorBundle\QueryBuilderRepositoryGeneratorBundle();
}

Configuration

Mandatory configuration

Add the bundles you want:

	query_builder_repository_generator:
		bundles:
    		- "<<YourBundleName>>"

Those bundles will have the repositories generated in the Repository directory of the bundles. Check the content by yourself.

Optional configuration

	query_builder_repository_generator:
		templates:
			top_repository: "QueryBuilderRepositoryGeneratorBundle:Generator:TopRepositoryTemplate.html.twig"
			column: "QueryBuilderRepositoryGeneratorBundle:Generator:ColumnTemplate.html.twig"
			association: "QueryBuilderRepositoryGeneratorBundle:Generator:AssociationTemplate.html.twig"
			bottom_repository: "QueryBuilderRepositoryGeneratorBundle:Generator:BottomRepositoryTemplate.html.twig"
	mapping:
		- 'AppBundle\Entity\Member':
			querybuilder_name: 'memberEntity' # the name of the entity used in the queryBuilder

The repository extends

You can specify a class to extends for each entity.

	repositories_extensions:
		- "AcmeBundle\Entity\Item": #the entity class
			extension_class: "\\Gedmo\\Tree\\Entity\\Repository\\MaterializedPathRepository" #the class to extends

The templates used by the generator can be set with these configurations.

	top_repository => The beginning of the repository file
	column => The template used for each column
	extra_column => A custom template of your choice
	bottom_repository => The end of the repository file

The extra_column template have the following variables:

	'entity' => $tableName,
	'entityDql' => lcfirst($tableName),
	'column' => ucfirst($columnName),
	'columnDql' => $columnName

Use generated repositories

In your Entity Repository, extends the generated repository.

	class UserRepository extends UserRepositoryBase

Your repository has now some predefined function like "filterById", "filterInId" for all the columns.

Create queries

Example:

	$qb = $this->createQueryBuilder('document');

	//filter on current user (where XX = YY)
   DocumentRepository::filterByUser($qb, $user);
   //filter on the extension list (where xxx IN () )
   DocumentRepository::filterInExtension($qb, $extensionList);

   //Join the tag entity
   $qb->join('document.tags', 'tag');
   //filter on the tag entity
   TagRepository::filterById($qb, $tagButton);

Regenerate files

Run the command:

php app/console qbrg:generate

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: Unknown
  • 更新时间: 2015-03-19