2023-08-28 13:53:04 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
declare(strict_types=1);
|
|
|
|
|
|
|
|
namespace App\Database\Migrations;
|
|
|
|
|
2024-05-29 10:24:13 +00:00
|
|
|
use Override;
|
|
|
|
|
2023-08-28 13:53:04 +00:00
|
|
|
class AddEpisodePreviewId extends BaseMigration
|
|
|
|
{
|
2024-05-29 10:24:13 +00:00
|
|
|
#[Override]
|
2023-08-28 13:53:04 +00:00
|
|
|
public function up(): void
|
|
|
|
{
|
|
|
|
$fields = [
|
|
|
|
'preview_id' => [
|
|
|
|
'type' => 'BINARY',
|
|
|
|
'constraint' => 16,
|
|
|
|
'after' => 'podcast_id',
|
|
|
|
],
|
|
|
|
];
|
|
|
|
|
|
|
|
$this->forge->addColumn('episodes', $fields);
|
|
|
|
|
|
|
|
// set preview_id as unique key
|
|
|
|
$prefix = $this->db->getPrefix();
|
|
|
|
$uniquePreviewId = <<<CODE_SAMPLE
|
|
|
|
ALTER TABLE `{$prefix}episodes`
|
|
|
|
ADD CONSTRAINT `preview_id` UNIQUE (`preview_id`);
|
|
|
|
CODE_SAMPLE;
|
|
|
|
|
|
|
|
$this->db->query($uniquePreviewId);
|
|
|
|
}
|
|
|
|
|
2024-05-29 10:24:13 +00:00
|
|
|
#[Override]
|
2023-08-28 13:53:04 +00:00
|
|
|
public function down(): void
|
|
|
|
{
|
|
|
|
$fields = ['preview_id'];
|
|
|
|
$this->forge->dropColumn('episodes', $fields);
|
|
|
|
}
|
|
|
|
}
|