<?php
declare(strict_types=1);
namespace DoctrineMigrations;
use Doctrine\DBAL\Schema\Schema;
use Doctrine\Migrations\AbstractMigration;
/**
* Auto-generated Migration: Please modify to your needs!
*/
final class Version20221026114546 extends AbstractMigration
{
public function getDescription(): string
{
return '';
}
public function up(Schema $schema): void
{
// this up() migration is auto-generated, please modify it to your needs
$this->addSql('CREATE SEQUENCE play_history_id_seq INCREMENT BY 1 MINVALUE 1 START 1');
$this->addSql('CREATE SEQUENCE song_id_seq INCREMENT BY 1 MINVALUE 1 START 1');
$this->addSql('CREATE SEQUENCE song_image_id_seq INCREMENT BY 1 MINVALUE 1 START 1');
$this->addSql('CREATE TABLE play_history (id INT NOT NULL, song_id INT NOT NULL, radio_id INT NOT NULL, start_date TIMESTAMP(0) WITHOUT TIME ZONE NOT NULL, end_date TIMESTAMP(0) WITHOUT TIME ZONE NOT NULL, PRIMARY KEY(id))');
$this->addSql('CREATE INDEX IDX_51A417FBA0BDB2F3 ON play_history (song_id)');
$this->addSql('CREATE INDEX IDX_51A417FB5B94ADD2 ON play_history (radio_id)');
$this->addSql('CREATE TABLE song (id INT NOT NULL, radio_id INT NOT NULL, image_id INT DEFAULT NULL, artist VARCHAR(255) NOT NULL, name VARCHAR(255) NOT NULL, description VARCHAR(255) DEFAULT NULL, duration INT DEFAULT NULL, song VARCHAR(255) DEFAULT NULL, active BOOLEAN NOT NULL, date_edit TIMESTAMP(0) WITHOUT TIME ZONE DEFAULT NULL, file_name VARCHAR(255) NOT NULL, file_size INT NOT NULL, updated_at TIMESTAMP(0) WITHOUT TIME ZONE NOT NULL, PRIMARY KEY(id))');
$this->addSql('CREATE INDEX IDX_33EDEEA15B94ADD2 ON song (radio_id)');
$this->addSql('CREATE UNIQUE INDEX UNIQ_33EDEEA13DA5256D ON song (image_id)');
$this->addSql('COMMENT ON COLUMN song.updated_at IS \'(DC2Type:datetime_immutable)\'');
$this->addSql('CREATE TABLE song_image (id INT NOT NULL, image VARCHAR(255) NOT NULL, image_size INT NOT NULL, updated_at TIMESTAMP(0) WITHOUT TIME ZONE NOT NULL, PRIMARY KEY(id))');
$this->addSql('COMMENT ON COLUMN song_image.updated_at IS \'(DC2Type:datetime_immutable)\'');
$this->addSql('ALTER TABLE play_history ADD CONSTRAINT FK_51A417FBA0BDB2F3 FOREIGN KEY (song_id) REFERENCES song (id) NOT DEFERRABLE INITIALLY IMMEDIATE');
$this->addSql('ALTER TABLE play_history ADD CONSTRAINT FK_51A417FB5B94ADD2 FOREIGN KEY (radio_id) REFERENCES radio (id) NOT DEFERRABLE INITIALLY IMMEDIATE');
$this->addSql('ALTER TABLE song ADD CONSTRAINT FK_33EDEEA15B94ADD2 FOREIGN KEY (radio_id) REFERENCES radio (id) NOT DEFERRABLE INITIALLY IMMEDIATE');
$this->addSql('ALTER TABLE song ADD CONSTRAINT FK_33EDEEA13DA5256D FOREIGN KEY (image_id) REFERENCES song_image (id) NOT DEFERRABLE INITIALLY IMMEDIATE');
}
public function down(Schema $schema): void
{
// this down() migration is auto-generated, please modify it to your needs
$this->addSql('CREATE SCHEMA public');
$this->addSql('DROP SEQUENCE play_history_id_seq CASCADE');
$this->addSql('DROP SEQUENCE song_id_seq CASCADE');
$this->addSql('DROP SEQUENCE song_image_id_seq CASCADE');
$this->addSql('ALTER TABLE play_history DROP CONSTRAINT FK_51A417FBA0BDB2F3');
$this->addSql('ALTER TABLE play_history DROP CONSTRAINT FK_51A417FB5B94ADD2');
$this->addSql('ALTER TABLE song DROP CONSTRAINT FK_33EDEEA15B94ADD2');
$this->addSql('ALTER TABLE song DROP CONSTRAINT FK_33EDEEA13DA5256D');
$this->addSql('DROP TABLE play_history');
$this->addSql('DROP TABLE song');
$this->addSql('DROP TABLE song_image');
}
}