-
Notifications
You must be signed in to change notification settings - Fork 159
Expand file tree
/
Copy pathAlterRoutineSQL.php
More file actions
35 lines (27 loc) · 1.11 KB
/
AlterRoutineSQL.php
File metadata and controls
35 lines (27 loc) · 1.11 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
33
34
35
<?php namespace DBDiff\SQLGen\DiffToSQL;
use DBDiff\SQLGen\SQLGenInterface;
use DBDiff\SQLGen\Dialect\DialectRegistry;
use DBDiff\SQLGen\Dialect\SQLDialectInterface;
class AlterRoutineSQL implements SQLGenInterface {
protected $obj;
protected SQLDialectInterface $dialect;
public function __construct($obj, SQLDialectInterface $dialect = null) {
$this->obj = $obj;
$this->dialect = $dialect ?? DialectRegistry::get();
}
public function getUp(): string {
$drop = $this->buildDrop($this->obj->targetDefinition, $this->obj->name);
return $drop . "\n" . $this->obj->sourceDefinition . ';';
}
public function getDown(): string {
$drop = $this->buildDrop($this->obj->sourceDefinition, $this->obj->name);
return $drop . "\n" . $this->obj->targetDefinition . ';';
}
private function buildDrop(string $definition, string $name): string {
$type = 'FUNCTION';
if (preg_match('/\bPROCEDURE\b/i', $definition)) {
$type = 'PROCEDURE';
}
return "DROP $type IF EXISTS " . $this->dialect->quote($name) . ';';
}
}