-
Notifications
You must be signed in to change notification settings - Fork 159
Expand file tree
/
Copy pathCreateRoutineSQL.php
More file actions
36 lines (28 loc) · 1.04 KB
/
CreateRoutineSQL.php
File metadata and controls
36 lines (28 loc) · 1.04 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
36
<?php namespace DBDiff\SQLGen\DiffToSQL;
use DBDiff\SQLGen\SQLGenInterface;
use DBDiff\SQLGen\Dialect\DialectRegistry;
use DBDiff\SQLGen\Dialect\SQLDialectInterface;
class CreateRoutineSQL 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 {
return $this->obj->definition . ';';
}
public function getDown(): string {
return $this->buildDrop($this->obj->definition, $this->obj->name);
}
/**
* Build a DROP statement that matches the routine type (PROCEDURE or FUNCTION).
*/
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) . ';';
}
}