2023-06-21 10:07:31 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
declare(strict_types=1);
|
|
|
|
|
|
|
|
namespace App\Database\Migrations;
|
|
|
|
|
2024-05-29 10:24:13 +00:00
|
|
|
use Override;
|
|
|
|
|
2023-06-21 10:07:31 +00:00
|
|
|
class AddFullTextSearchIndexes extends BaseMigration
|
|
|
|
{
|
2024-05-29 10:24:13 +00:00
|
|
|
#[Override]
|
2023-06-21 10:07:31 +00:00
|
|
|
public function up(): void
|
|
|
|
{
|
|
|
|
$prefix = $this->db->getPrefix();
|
|
|
|
|
2023-08-26 13:03:01 +00:00
|
|
|
$createQuery = <<<SQL
|
2023-09-11 15:43:14 +00:00
|
|
|
ALTER TABLE {$prefix}episodes DROP INDEX title;
|
2023-08-26 13:03:01 +00:00
|
|
|
SQL;
|
2023-06-21 10:07:31 +00:00
|
|
|
|
|
|
|
$this->db->query($createQuery);
|
|
|
|
|
2023-08-26 13:03:01 +00:00
|
|
|
$createQuery = <<<SQL
|
2023-06-21 10:07:31 +00:00
|
|
|
ALTER TABLE {$prefix}episodes
|
|
|
|
ADD FULLTEXT episodes_search (title, description_markdown, slug, location_name);
|
2023-08-26 13:03:01 +00:00
|
|
|
SQL;
|
2023-06-21 10:07:31 +00:00
|
|
|
|
|
|
|
$this->db->query($createQuery);
|
|
|
|
|
2023-08-26 13:03:01 +00:00
|
|
|
$createQuery = <<<SQL
|
2023-06-21 10:07:31 +00:00
|
|
|
ALTER TABLE {$prefix}podcasts
|
|
|
|
ADD FULLTEXT podcasts_search (title, description_markdown, handle, location_name);
|
2023-08-26 13:03:01 +00:00
|
|
|
SQL;
|
2023-06-21 10:07:31 +00:00
|
|
|
|
|
|
|
$this->db->query($createQuery);
|
|
|
|
}
|
|
|
|
|
2024-05-29 10:24:13 +00:00
|
|
|
#[Override]
|
2023-06-21 10:07:31 +00:00
|
|
|
public function down(): void
|
|
|
|
{
|
|
|
|
$prefix = $this->db->getPrefix();
|
|
|
|
|
2023-08-26 13:03:01 +00:00
|
|
|
$createQuery = <<<SQL
|
2023-06-21 10:07:31 +00:00
|
|
|
ALTER TABLE {$prefix}episodes
|
2023-09-11 15:43:14 +00:00
|
|
|
DROP INDEX episodes_search;
|
2023-08-26 13:03:01 +00:00
|
|
|
SQL;
|
2023-06-21 10:07:31 +00:00
|
|
|
|
|
|
|
$this->db->query($createQuery);
|
|
|
|
|
2023-08-26 13:03:01 +00:00
|
|
|
$createQuery = <<<SQL
|
2023-06-21 10:07:31 +00:00
|
|
|
ALTER TABLE {$prefix}podcasts
|
2023-09-11 15:43:14 +00:00
|
|
|
DROP INDEX podcasts_search;
|
2023-08-26 13:03:01 +00:00
|
|
|
SQL;
|
2023-06-21 10:07:31 +00:00
|
|
|
|
|
|
|
$this->db->query($createQuery);
|
|
|
|
}
|
|
|
|
}
|