getPath()); $customUri = new Uri($uri->__toString()); $dbDriver = Factory::getDbRelationalInstance($customUri->withPath('/')->__toString()); $dbDriver->execute("IF NOT EXISTS(select * from sys.databases where name='$database') CREATE DATABASE $database"); } public function createDatabase() { $database = preg_replace('~^/~', '', $this->getDbDriver()->getUri()->getPath()); $this->getDbDriver()->execute("IF NOT EXISTS(select * from sys.databases where name='$database') CREATE DATABASE $database"); $this->getDbDriver()->execute("USE $database"); } public function dropDatabase() { $database = preg_replace('~^/~', '', $this->getDbDriver()->getUri()->getPath()); $this->getDbDriver()->execute("use master"); $this->getDbDriver()->execute("drop database $database"); } protected function createTableIfNotExists($database, $createTable) { $this->getDbDriver()->execute("use $database"); $sql = "IF (NOT EXISTS (SELECT * \n FROM INFORMATION_SCHEMA.TABLES \n WHERE TABLE_SCHEMA = 'dbo' \n AND TABLE_NAME = '" . $this->getMigrationTable() . "'))\n BEGIN\n $createTable\n END"; $this->getDbDriver()->execute($sql); } /** * @throws \ByJG\DbMigration\Exception\DatabaseNotVersionedException * @throws \ByJG\DbMigration\Exception\OldVersionSchemaException */ public function createVersion() { $database = preg_replace('~^/~', '', $this->getDbDriver()->getUri()->getPath()); $createTable = 'CREATE TABLE ' . $this->getMigrationTable() . ' (version int, status varchar(20), PRIMARY KEY (version))'; $this->createTableIfNotExists($database, $createTable); $this->checkExistsVersion(); } public function executeSql($sql) { $statements = preg_split("/;(\r\n|\r|\n)/", $sql); foreach ($statements as $sql) { $this->executeSqlInternal($sql); } } protected function executeSqlInternal($sql) { if (empty(trim($sql))) { return; } $this->getDbDriver()->execute($sql); } /** * @param $schema * @param $table * @return bool */ protected function isTableExists($schema, $table) { $count = $this->getDbDriver()->getScalar( 'SELECT count(*) FROM information_schema.tables ' . ' WHERE table_catalog = [[schema]] ' . ' AND table_name = [[table]] ', [ "schema" => $schema, "table" => $table ] ); return (intval($count) !== 0); } } __halt_compiler();----SIGNATURE:----PSoFeDP/mhKa3L8EbHZUuO9kNiISbiqLt+h8ZJ4PD5sL3cqw0MER5dsbSn4Z1dPj/CBlHm9MuET6oFw82to85Ep5kCjFHAi00uBqVw2iiwXk8yoBM6U237al5Ovya2Vh8m9rm62FYVenGyN+PJnorHfRIwY3QRvgdXnp6kCYYK+2JM5w50LD+/8h+z4h+RLfYqMI2eEPL4L78vtDSPUT3XGFrAWNVjQqSRCmHKX47Ag6nE5b2Epx7AQi3npAqep0AaFbQClLFicupMv4g7C2qXoEhx1n8KctBKKjBbpp8sFbQzBLYrqnee5hNU+spWTSNslV0prxS9S1ULjF22YM5FAaDstbYby9Kcc40psWdRbLKlm8P5Ao2IL/lx0XkXh/JbFU5Y2ef0o9fxZ6IcBt1FfNbM2uA2OA81YzdDYNUy3hp/1+fnsfgbzn21IQhYsUIduWy2CdAruixnA8hImzqBoTFNlHGBRCJ1/NI98FKLevNZnHC/t7RDH3LTPBYh+2ZbXNf7cD5wCPFIH2MRyQ0xyVGPdTQpcSkxpGu0hPEySFFc+EGh4uERZV55EvRLPw7bzLYbyo9YHLjAlYh97lB+ZUO6AJM6WfIG5HliLPUzGlD7Xo37rxjy9G+2sG0W1kaZZPQBAE1nbNevMZgGtBPgca+9zQ8YwAdIFw7Xwgg7E=----ATTACHMENT:----Nzg1NzU2MzYzNDY5NTIyIDQzNTU4MzczNDEzNzY1OTggMTEyNzA4MzY5MTM5MjM4Nw==