Passed
Push — dev ( 98511f...00baf5 )
by Janko
15:17
created

Version20250603172257_MoveBaseDamage   A

Complexity

Total Complexity 3

Size/Duplication

Total Lines 26
Duplicated Lines 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
eloc 17
c 1
b 0
f 0
dl 0
loc 26
rs 10
wmc 3

3 Methods

Rating   Name   Duplication   Size   Complexity  
A up() 0 12 1
A down() 0 3 1
A getDescription() 0 3 1
1
<?php
2
3
declare(strict_types=1);
4
5
namespace Stu\Migrations\Pgsql;
6
7
use Doctrine\DBAL\Schema\Schema;
8
use Doctrine\Migrations\AbstractMigration;
9
10
final class Version20250603172257_MoveBaseDamage extends AbstractMigration
11
{
12
    public function getDescription(): string
13
    {
14
        return 'Moves spacecraft base_damage to energy weapon system data.';
15
    }
16
17
    public function up(Schema $schema): void
18
    {
19
        $this->addSql(<<<'SQL'
20
            UPDATE stu_spacecraft_system ss
21
            SET DATA = (
22
                SELECT '{"baseDamage":' || s.base_damage || '}'
23
                FROM stu_spacecraft s
24
                WHERE s.id = ss.spacecraft_id
25
            )
26
            WHERE ss.system_type = 5
27
        SQL);
28
        $this->addSql(<<<'SQL'
29
            ALTER TABLE stu_spacecraft DROP base_damage
30
        SQL);
31
    }
32
33
    public function down(Schema $schema): void
34
    {
35
        $this->addSql(<<<'SQL'
36
            ALTER TABLE stu_spacecraft ADD base_damage SMALLINT NOT NULL
37
        SQL);
38
    }
39
}
40