vendor/pimcore/pimcore/bundles/CoreBundle/Migrations/Version20220425082914.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 Version20220425082914 extends AbstractMigration
  19. {
  20.     public function getDescription(): string
  21.     {
  22.         return 'Improve data object grid loading performance';
  23.     }
  24.     public function up(Schema $schema): void
  25.     {
  26.         if ($schema->getTable('objects')->hasIndex('type')) {
  27.             $this->addSql('ALTER TABLE `objects` DROP INDEX `type`');
  28.         }
  29.         if (!$schema->getTable('objects')->hasIndex('type_path_classId')) {
  30.             $this->addSql('ALTER TABLE `objects` ADD INDEX `type_path_classId` (o_type, o_path, o_classId)');
  31.         }
  32.     }
  33.     public function down(Schema $schema): void
  34.     {
  35.         if (!$schema->getTable('objects')->hasIndex('type')) {
  36.             $this->addSql('ALTER TABLE `objects` ADD INDEX `type` (o_type)');
  37.         }
  38.         if ($schema->getTable('objects')->hasIndex('type_path_classId')) {
  39.             $this->addSql('ALTER TABLE `objects` DROP INDEX `type_path_classId`');
  40.         }
  41.     }
  42. }