51 lines
1.8 KiB
PHP
51 lines
1.8 KiB
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace App\Entity\Migration;
|
|
|
|
use Doctrine\DBAL\ParameterType;
|
|
use Doctrine\DBAL\Schema\Schema;
|
|
use Doctrine\Migrations\AbstractMigration;
|
|
|
|
/**
|
|
* Auto-generated Migration: Please modify to your needs!
|
|
*/
|
|
final class Version20191101065730 extends AbstractMigration
|
|
{
|
|
public function up(Schema $schema): void
|
|
{
|
|
$this->addSql('CREATE TABLE station_playlist_schedules (id INT AUTO_INCREMENT NOT NULL, playlist_id INT DEFAULT NULL, start_time SMALLINT NOT NULL, end_time SMALLINT NOT NULL, start_date VARCHAR(10) DEFAULT NULL, end_date VARCHAR(10) DEFAULT NULL, days VARCHAR(50) DEFAULT NULL, INDEX IDX_C61009BA6BBD148 (playlist_id), PRIMARY KEY(id)) DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci ENGINE = InnoDB');
|
|
$this->addSql('ALTER TABLE station_playlist_schedules ADD CONSTRAINT FK_C61009BA6BBD148 FOREIGN KEY (playlist_id) REFERENCES station_playlists (id) ON DELETE CASCADE');
|
|
}
|
|
|
|
public function postUp(Schema $schema): void
|
|
{
|
|
$playlists = $this->connection->fetchAllAssociative(
|
|
'SELECT sp.* FROM station_playlists AS sp WHERE sp.type = ?',
|
|
['scheduled'],
|
|
[ParameterType::STRING]
|
|
);
|
|
|
|
foreach ($playlists as $row) {
|
|
$this->connection->insert('station_playlist_schedules', [
|
|
'playlist_id' => $row['id'],
|
|
'start_time' => $row['schedule_start_time'],
|
|
'end_time' => $row['schedule_end_time'],
|
|
'days' => $row['schedule_days'],
|
|
]);
|
|
|
|
$this->connection->update('station_playlists', [
|
|
'type' => 'default',
|
|
], [
|
|
'id' => $row['id'],
|
|
]);
|
|
}
|
|
}
|
|
|
|
public function down(Schema $schema): void
|
|
{
|
|
$this->addSql('DROP TABLE station_playlist_schedules');
|
|
}
|
|
}
|