| @@ 12-48 (lines=37) @@ | ||
| 9 | use Oro\Bundle\MigrationBundle\Migration\ArrayLogger; |
|
| 10 | use Oro\Bundle\MigrationBundle\Migration\ParametrizedMigrationQuery; |
|
| 11 | ||
| 12 | class AccountNameExprIndexQuery extends ParametrizedMigrationQuery |
|
| 13 | { |
|
| 14 | public function getDescription() |
|
| 15 | { |
|
| 16 | $logger = new ArrayLogger(); |
|
| 17 | $logger->info( |
|
| 18 | 'Create additional expression index on PostgreSQL' |
|
| 19 | ); |
|
| 20 | $this->doExecute($logger, true); |
|
| 21 | ||
| 22 | return $logger->getMessages(); |
|
| 23 | } |
|
| 24 | ||
| 25 | /** |
|
| 26 | * {@inheritdoc} |
|
| 27 | */ |
|
| 28 | public function execute(LoggerInterface $logger) |
|
| 29 | { |
|
| 30 | $this->doExecute($logger); |
|
| 31 | } |
|
| 32 | ||
| 33 | /** |
|
| 34 | * {@inheritdoc} |
|
| 35 | */ |
|
| 36 | public function doExecute(LoggerInterface $logger, $dryRun = false) |
|
| 37 | { |
|
| 38 | $platform = $this->connection->getDatabasePlatform(); |
|
| 39 | if ($platform instanceof PostgreSQL92Platform) { |
|
| 40 | $createIndex = 'CREATE INDEX account_name_expr_idx ON orocrm_account (lower(name))'; |
|
| 41 | ||
| 42 | $this->logQuery($logger, $createIndex); |
|
| 43 | if (!$dryRun) { |
|
| 44 | $this->connection->executeUpdate($createIndex); |
|
| 45 | } |
|
| 46 | } |
|
| 47 | } |
|
| 48 | } |
|
| 49 | ||
| @@ 12-48 (lines=37) @@ | ||
| 9 | use Oro\Bundle\MigrationBundle\Migration\ArrayLogger; |
|
| 10 | use Oro\Bundle\MigrationBundle\Migration\ParametrizedMigrationQuery; |
|
| 11 | ||
| 12 | class UpdateChannelJsonArrayQuery extends ParametrizedMigrationQuery |
|
| 13 | { |
|
| 14 | public function getDescription() |
|
| 15 | { |
|
| 16 | $logger = new ArrayLogger(); |
|
| 17 | $logger->info( |
|
| 18 | 'Convert a column with "json_array(text)" type to "json_array" type on PostgreSQL >= 9.2 and Doctrine 2.5' |
|
| 19 | ); |
|
| 20 | $this->doExecute($logger, true); |
|
| 21 | ||
| 22 | return $logger->getMessages(); |
|
| 23 | } |
|
| 24 | ||
| 25 | /** |
|
| 26 | * {@inheritdoc} |
|
| 27 | */ |
|
| 28 | public function execute(LoggerInterface $logger) |
|
| 29 | { |
|
| 30 | $this->doExecute($logger); |
|
| 31 | } |
|
| 32 | ||
| 33 | /** |
|
| 34 | * {@inheritdoc} |
|
| 35 | */ |
|
| 36 | public function doExecute(LoggerInterface $logger, $dryRun = false) |
|
| 37 | { |
|
| 38 | $platform = $this->connection->getDatabasePlatform(); |
|
| 39 | if ($platform instanceof PostgreSQL92Platform) { |
|
| 40 | $updateSql = 'ALTER TABLE orocrm_channel ALTER COLUMN data TYPE JSON USING data::JSON'; |
|
| 41 | ||
| 42 | $this->logQuery($logger, $updateSql); |
|
| 43 | if (!$dryRun) { |
|
| 44 | $this->connection->executeUpdate($updateSql); |
|
| 45 | } |
|
| 46 | } |
|
| 47 | } |
|
| 48 | } |
|
| 49 | ||