<?php
declare(strict_types=1);
namespace DoctrineMigrations;
use Doctrine\DBAL\Schema\Schema;
use Doctrine\Migrations\AbstractMigration;
/**
* Add composite indexes for sponsor-campaign-statistics:
* - activity (campaign_id, status, created_at) - sort by activity creation date
* - activity (campaign_id, status, payed_at) - filter paid/unpaid
* - activity (campaign_id, status, followers) - sort by followers
* Note: activity.video_id and creator.country_id already have indexes (from initial schema).
*/
final class Version20260319120000 extends AbstractMigration
{
public function getDescription(): string
{
return 'Add indexes for activity and creator statistics query optimization';
}
public function up(Schema $schema): void
{
$this->addSql('CREATE INDEX idx_activity_campaign_status_created ON activity (campaign_id, status, created_at)');
$this->addSql('CREATE INDEX idx_activity_campaign_status_payed ON activity (campaign_id, status, payed_at)');
$this->addSql('CREATE INDEX idx_activity_campaign_status_followers ON activity (campaign_id, status, followers)');
}
public function down(Schema $schema): void
{
$this->addSql('DROP INDEX idx_activity_campaign_status_created ON activity');
$this->addSql('DROP INDEX idx_activity_campaign_status_payed ON activity');
$this->addSql('DROP INDEX idx_activity_campaign_status_followers ON activity');
}
}