Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/intaro/custom-index-bundle

The bundle allows to describe and create non-standard database indexes for entities
https://github.com/intaro/custom-index-bundle

bundle php symfony symfony-bundle

Last synced: about 1 month ago
JSON representation

The bundle allows to describe and create non-standard database indexes for entities

Awesome Lists containing this project

README

        

# CustomIndexBundle

The CustomIndexBundle allows create index for doctrine entities using attribute with entity definition and console command.

## Installation

CustomIndexBundle requires Symfony 5 or higher. Works only with PostgreSQL.

Run into your project directory:
```
$ composer require intaro/custom-index-bundle
```

Register the bundle in `config/bundles.php`:

```php

['all' => true],
];
```

If your project have many schemas in single database and command must generate custom indexes only for one schema then add in your `config.yml`:

```yaml
intaro_custom_index:
search_in_all_schemas: false
allowed_index_types: ['gin', 'gist', 'btree', 'hash']

```

Default value of `search_in_all_schemas` is `true`.
If you have different entities in different schemas and you need to update custom indexes in all schemas at once then you must set `search_in_all_schemas` to `true` or omit this config.
If you have database with only public schema then `search_in_all_schemas` value doesn't matter.

Parameter `allowed_index_types` helps to exclude some types of indexes. If someone will try to use excluded type, command `intaro:doctrine:index:update` will return an error.
Default value is `['gin', 'gist', 'btree', 'hash']`.

## Usage

1) Add attributes in your entity

```php
'`).
* `unique` - index is unique (default = false).
* `using` - corresponds to `USING` directive in PostgreSQL `CREATE INDEX` command.
* `where` - corresponds to `WHERE` directive in PostgreSQL `CREATE INDEX` command.

Required only `columns` property.

2) Use `intaro:doctrine:index:update` command for update db.

```
php app/console intaro:doctrine:index:update
```

You may use `dump-sql` parameter for dump sql with `DROP/CREATE INDEX` commands

```
php app/console intaro:doctrine:index:update --dump-sql
```

## Examples

Create index using `pg_trgm` extension:
```php