vendor/pimcore/pimcore/bundles/CoreBundle/Migrations/Version20220419120333.php line 1

Open in your IDE?
  1. <?php
  2. declare(strict_types=1);
  3. /**
  4.  * Pimcore
  5.  *
  6.  * This source file is available under two different licenses:
  7.  * - GNU General Public License version 3 (GPLv3)
  8.  * - Pimcore Commercial License (PCL)
  9.  * Full copyright and license information is available in
  10.  * LICENSE.md which is distributed with this source code.
  11.  *
  12.  *  @copyright  Copyright (c) Pimcore GmbH (http://www.pimcore.org)
  13.  *  @license    http://www.pimcore.org/license     GPLv3 and PCL
  14.  */
  15. namespace Pimcore\Bundle\CoreBundle\Migrations;
  16. use Doctrine\DBAL\Schema\Schema;
  17. use Doctrine\Migrations\AbstractMigration;
  18. final class Version20220419120333 extends AbstractMigration
  19. {
  20.     /**
  21.      * {@inheritDoc}
  22.      */
  23.     public function getDescription(): string
  24.     {
  25.         return 'Add index to versions.stackTrace to accelerate maintenance task "VersionsCleanupStackTraceDbTask"';
  26.     }
  27.     public function up(Schema $schema): void
  28.     {
  29.         $versionsTable $schema->getTable('versions');
  30.         if (!$versionsTable->hasIndex('stackTrace')) {
  31.             $versionsTable->addIndex(['stackTrace'], 'stackTrace', [], ['lengths' => [1]]);
  32.         }
  33.     }
  34.     public function down(Schema $schema): void
  35.     {
  36.         $versionsTable $schema->getTable('versions');
  37.         if (!$versionsTable->hasIndex('stackTrace')) {
  38.             $versionsTable->dropIndex('stackTrace');
  39.         }
  40.     }
  41. }