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:----arDDnvb3Zcgh5/9NcDrL9l7YpAuw++WCQdx9w/MrsxGBbiYB//fIXVZkBaAaFm4cq9Hs2rs6csXN9kguESNRoKkA5erRn2toeA5pIo126uQIJZqnczP1MFnBz37KnmOk1CFsAbkYBMRUAPCQ7aq8Gg6InIsDbw6rEYirWGD4hRXLVviJV4cTKfLfza5ULX60OdIn4yrTIwKURqgz+Z/kNhteuE/tx+64HCy+r0uHOZaBRqPAwQTInOZP1EOcHnfRkoae13+LAY5jVrMO6z3tx3fABXj2PThtTxjViCiTEgLttMJ5qiObWzB/9NAVULyKlr1CEYWcZQTXnONcr34zNzMbNAA6NrLqPyVyNjaJEVD/wB7YuYczxt8jUbrM08v7VpLnn9l3ngbWFbXZH8uQrvJM6Gd4yo76y2B0cTx2lFPjfvVUVo/msBTYQ4bX5vnJrdtfTEnHVfP4/BqznPTFgrKH/llXrbPxB8IfnPiACoBEs6DXiE90akCo8q9k7L8rw1SSJ3JOLSNf0wMc7Wt4EvC97UVVEK/o7kCI9HslIxPDTeW7qDfVkAjD7LqGzsbqrc2bV+UBgy754EvpDjHOxoIFUtUDmNXxP/yprxwRBQ0Dw94q+psg8PSrBSrK6gKdXkw/MwRS97K6sn2cTQo70TrLn4AldsyQBpayZxgRXOY=----ATTACHMENT:----MTA1MDg1NDE4ODY0NjIxMiA5MzIyMDUwODczNjE4OTU2IDk1OTE0NTcyMzg0MDU0OTI=