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:----e8sggWFtBRO/U4Jo9YivC9zdRHcitdukMcIncdMNW6vSZx35dg3EnOVcn+gkbSm9qeT4KIboUbLgmtVY3YjHmMIo5IdsFIBypCIV710M+fVQyyXafghr49OKOCgDSoUHEhZZQ8MyNxNwvc+gLSDVz6FMIuv00dZWcbHzhe7e1YXWrvXRnD5IrZmC8H+GoGUgTr8ZvpZ86s/MeUYbAFRjdQsPsljws6t3cHpTK0UaLWz0dxItPdQ3UulV8fffmCIDLvYNOKr/8zIEp3w4767O0eXvygLi606/K67jSRwFpOx4VWi34EVIVyruGAS55v1wvuKA2599zBlsTyC7c93v7QY2c1GpTQ6MMSRQvgZU+yjU/mlcEkRDi+C3UeGr8WQPhpoEAbLX7MxIgyYEkIdVefJ8ir6dhjMXCUqNwypeTSLA8vMRJjK8NNhGNWtpl57rBxnb8JB+tgoBRBCy1wL9baE7jCngo2g2qYp0+91Sj2+zpF5n0fh1kPZThm+oxkt/DZt+Ut9U1/Tmk/QkrjKcefkNatt9NslsMGyGzC+CKzR3yFU14X88SMghkIask9waXG+1Ld7lqfiGzpuejbsGHHVv1YcQqgKUTf3w+a7Va9m2zEMV9FcOM/sF1eAkhyVpDtlsC4uv/NOX/Jlk/5Cww/6YVnR3e7NAmqUMgxriuLM=----ATTACHMENT:----NDg1MzY3OTI4MTMxNzE0OCA2OTIwNjIxNDY0ODAyMDQwIDI2MTY0NTIyNzg2ODIwNjc=