migrations/Version20220522153052.php line 1

Open in your IDE?
  1. <?php
  2. declare(strict_types=1);
  3. namespace DoctrineMigrations;
  4. use Doctrine\DBAL\Schema\Schema;
  5. use Doctrine\Migrations\AbstractMigration;
  6. /**
  7.  * Auto-generated Migration: Please modify to your needs!
  8.  */
  9. final class Version20220522153052 extends AbstractMigration
  10. {
  11.     public function getDescription(): string
  12.     {
  13.         return '';
  14.     }
  15.     public function up(Schema $schema): void
  16.     {
  17.         // this up() migration is auto-generated, please modify it to your needs
  18.         $this->addSql('CREATE SEQUENCE project_report_id_seq INCREMENT BY 1 MINVALUE 1 START 1');
  19.         $this->addSql('CREATE SEQUENCE project_task_log_id_seq INCREMENT BY 1 MINVALUE 1 START 1');
  20.         $this->addSql('CREATE SEQUENCE task_user_log_id_seq INCREMENT BY 1 MINVALUE 1 START 1');
  21.         $this->addSql('CREATE TABLE project_report (id INT NOT NULL, project_id INT NOT NULL, date_at TIMESTAMP(0) WITHOUT TIME ZONE NOT NULL, status INT NOT NULL, PRIMARY KEY(id))');
  22.         $this->addSql('CREATE INDEX IDX_D38B9CCE166D1F9C ON project_report (project_id)');
  23.         $this->addSql('COMMENT ON COLUMN project_report.date_at IS \'(DC2Type:datetime_immutable)\'');
  24.         $this->addSql('CREATE TABLE project_task_log (id INT NOT NULL, project_report_id INT NOT NULL, name VARCHAR(255) NOT NULL, key VARCHAR(255) NOT NULL, epic_name VARCHAR(255) NOT NULL, PRIMARY KEY(id))');
  25.         $this->addSql('CREATE INDEX IDX_DDF31B995AEEE117 ON project_task_log (project_report_id)');
  26.         $this->addSql('CREATE TABLE task_user_log (id INT NOT NULL, employee_id INT NOT NULL, project_task_log_id INT DEFAULT NULL, cost DOUBLE PRECISION NOT NULL, hours DOUBLE PRECISION NOT NULL, value DOUBLE PRECISION NOT NULL, k DOUBLE PRECISION NOT NULL, cost_customer DOUBLE PRECISION NOT NULL, hours_costomer DOUBLE PRECISION NOT NULL, PRIMARY KEY(id))');
  27.         $this->addSql('CREATE INDEX IDX_24E9E3028C03F15C ON task_user_log (employee_id)');
  28.         $this->addSql('CREATE INDEX IDX_24E9E30219012EAE ON task_user_log (project_task_log_id)');
  29.         $this->addSql('ALTER TABLE project_report ADD CONSTRAINT FK_D38B9CCE166D1F9C FOREIGN KEY (project_id) REFERENCES project (id) NOT DEFERRABLE INITIALLY IMMEDIATE');
  30.         $this->addSql('ALTER TABLE project_task_log ADD CONSTRAINT FK_DDF31B995AEEE117 FOREIGN KEY (project_report_id) REFERENCES project_report (id) NOT DEFERRABLE INITIALLY IMMEDIATE');
  31.         $this->addSql('ALTER TABLE task_user_log ADD CONSTRAINT FK_24E9E3028C03F15C FOREIGN KEY (employee_id) REFERENCES employee (id) NOT DEFERRABLE INITIALLY IMMEDIATE');
  32.         $this->addSql('ALTER TABLE task_user_log ADD CONSTRAINT FK_24E9E30219012EAE FOREIGN KEY (project_task_log_id) REFERENCES project_task_log (id) NOT DEFERRABLE INITIALLY IMMEDIATE');
  33.     }
  34.     public function down(Schema $schema): void
  35.     {
  36.         // this down() migration is auto-generated, please modify it to your needs
  37.         $this->addSql('CREATE SCHEMA public');
  38.         $this->addSql('ALTER TABLE project_task_log DROP CONSTRAINT FK_DDF31B995AEEE117');
  39.         $this->addSql('ALTER TABLE task_user_log DROP CONSTRAINT FK_24E9E30219012EAE');
  40.         $this->addSql('DROP SEQUENCE project_report_id_seq CASCADE');
  41.         $this->addSql('DROP SEQUENCE project_task_log_id_seq CASCADE');
  42.         $this->addSql('DROP SEQUENCE task_user_log_id_seq CASCADE');
  43.         $this->addSql('DROP TABLE project_report');
  44.         $this->addSql('DROP TABLE project_task_log');
  45.         $this->addSql('DROP TABLE task_user_log');
  46.     }
  47. }