-
Notifications
You must be signed in to change notification settings - Fork 159
Expand file tree
/
Copy pathAlterTableChangeConstraintSQL.php
More file actions
32 lines (23 loc) · 1.05 KB
/
AlterTableChangeConstraintSQL.php
File metadata and controls
32 lines (23 loc) · 1.05 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
<?php namespace DBDiff\SQLGen\DiffToSQL;
use DBDiff\SQLGen\SQLGenInterface;
use DBDiff\SQLGen\Dialect\DialectRegistry;
use DBDiff\SQLGen\Dialect\SQLDialectInterface;
class AlterTableChangeConstraintSQL implements SQLGenInterface {
protected $obj;
protected SQLDialectInterface $dialect;
public function __construct($obj, SQLDialectInterface $dialect = null) {
$this->obj = $obj;
$this->dialect = $dialect ?? DialectRegistry::get();
}
private function buildChange(string $dropSchema, string $addSchema): string {
$t = $this->dialect->quote($this->obj->table);
$drop = $this->dialect->dropConstraint($this->obj->table, $this->obj->name, $dropSchema);
return "$drop\nALTER TABLE $t ADD $addSchema;";
}
public function getUp(): string {
return $this->buildChange($this->obj->diff->getOldValue(), $this->obj->diff->getNewValue());
}
public function getDown(): string {
return $this->buildChange($this->obj->diff->getNewValue(), $this->obj->diff->getOldValue());
}
}