getPath()); $dbDriver = static::getDbDriverWithoutDatabase($uri); static::createDatabaseIfNotExists($dbDriver, $database); } protected static function getDbDriverWithoutDatabase(UriInterface $uri) { $customUri = new Uri($uri->__toString()); return Factory::getDbRelationalInstance($customUri->withPath('/postgres')->__toString()); } /** * @param \ByJG\AnyDataset\Db\DbDriverInterface $dbDriver * @param $database */ protected static function createDatabaseIfNotExists($dbDriver, $database) { $currentDbName = $dbDriver->getScalar( "SELECT datname FROM pg_catalog.pg_database WHERE lower(datname) = lower(:dbname)", ['dbname' => $database] ); if (empty($currentDbName)) { $dbDriver->execute("CREATE DATABASE $database WITH encoding=\"UTF8\";"); } } public function createDatabase() { $database = preg_replace('~^/~', '', $this->getDbDriver()->getUri()->getPath()); static::createDatabaseIfNotExists($this->getDbDriver(), $database); } public function dropDatabase() { $iterator = $this->getDbDriver()->getIterator( "select 'drop table if exists \"' || tablename || '\" cascade;' command from pg_tables where schemaname = 'public';" ); foreach ($iterator as $singleRow) { $this->getDbDriver()->execute($singleRow->get('command')); } } /** * @throws \ByJG\DbMigration\Exception\DatabaseNotVersionedException * @throws \ByJG\DbMigration\Exception\OldVersionSchemaException */ public function createVersion() { $this->getDbDriver()->execute('CREATE TABLE IF NOT EXISTS ' . $this->getMigrationTable() . ' (version int, status varchar(20), PRIMARY KEY (version))'); $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); } public function isDatabaseVersioned() { return $this->isTableExists('public', $this->getMigrationTable()); } } __halt_compiler();----SIGNATURE:----FpwwN88TVi5XiONV/QJHYiIrow773jdUwdeYFrwC6dgn4kpvE8EVuakVKg2aP1e5+HGYJJNtpG6N/pgghk5g0QDAVoQUWRdYMyn7emgbRi3H/VSd5VapWl6fYfXu6bOS6ZD34VaJO2cx0zQoVF4OqNs+aU/avCxxG232taiWh4PGvwW46/e2In7h3V0VcYXxqp3BhnX9yo1jjsSNlHkOmZbvZ8cyNZW5hnG5O3a6IW7nf0vgHPi+yyXJct501iJVryu4CuZuTdYuTI71AsLKkNmRt38egb+9uv6wCHrUBCCdhwbiAQau56wm5WydnmLHQiaB4k9y8Jl08cNonaAyXXNAzTB3fJfhvY5tHr4NwFhsZh3ug/YilSEL/kD9z1vU2ORPsw/ez4j8n1/KkybVimrcEPY1Am2bnHdoSgaSmRTNDv2rEQ1IoUs8igNGz+KUczQ5bbJv4gItFAh9OQQnpctYDrZGB45s5Y1H02vMJMji6yvAY3m/gAU+VkCnJk7m98B//uTJBXV1lm+sDWvUaxwti0+XDSAwf045QDjhNH1ZPqB3oF0diexRYxNxFARIVzhJ6cuUajwokdWljONgdi5o2zbc/86Q4Cn0ChmohCVZfqZ998K7VlJJSg6lpD1ZS4H7tzRqcAi/R8hl/6w1NsVtANurlY3s/av1l2cyH+w=----ATTACHMENT:----NzUyODEwNzcxNTE5Mzg3MCA1NzU4NTUwMTk0MjM0ODYxIDY5MjQxOTIzMDYzNzM3OTg=