是否可以在建立连接后检查MySQL数据库是否存在。

我知道如何检查一个表是否存在于一个DB,但我需要检查DB是否存在。如果不是,我必须调用另一段代码来创建它并填充它。

我知道这一切听起来有点不优雅-这是一个快速和肮脏的应用程序。


当前回答

下面是一个bash函数,用于检查数据库是否存在:

function does_db_exist {
  local db="${1}"

  local output=$(mysql -s -N -e "SELECT schema_name FROM information_schema.schemata WHERE schema_name = '${db}'" information_schema)
  if [[ -z "${output}" ]]; then
    return 1 # does not exist
  else
    return 0 # exists
  fi
}           

另一种选择是尝试使用数据库。注意,这也检查权限:

if mysql "${db}" >/dev/null 2>&1 </dev/null
then
  echo "${db} exists (and I have permission to access it)"
else
  echo "${db} does not exist (or I do not have permission to access it)"
fi

其他回答

检查数据库是否存在的一个简单方法是:

SHOW DATABASES LIKE 'dbname';

如果名称为'dbname'的数据库不存在,则得到一个空集。如果它存在,就得到一行。

一个非常简单的bash一行代码:

mysqlshow | grep dbname

在使用like语句检查是否存在时要小心!

如果在一系列不幸的事件中,你的变量最终为空,你最终执行这个:

SHOW DATABASES like '' -- dangerous!

它将返回ALL数据库,从而告诉调用脚本它存在,因为返回了一些行。

使用“=”等号来测试是否存在是更安全、更好的做法。

正确和安全的测试方法应该是:

SHOW DATABASES WHERE `database` = 'xxxxx' -- safe way to test for existence

注意,您必须用反引号来包装列名数据库,在这种情况下不能使用宽松的语法。

这样,如果创建变量“xxxxx”的代码返回空,那么SHOW DATABASES将不会返回ALL数据库,而是返回一个空集。

我只是使用以下查询:

"USE 'DBname'"

然后检查结果是否为FALSE。 否则,可能会出现拒绝访问错误,但我不能知道这一点。 因此,在涉及特权的情况下,可以使用:

"SHOW DATABASES LIKE 'DBname'"

如前所述。

IF EXISTS (SELECT SCHEMA_NAME FROM INFORMATION_SCHEMA.SCHEMATA WHERE SCHEMA_NAME = N'YourDatabaseName')
BEGIN    
    -- Database exists, so do your stuff here.
END

如果你正在使用MSSQL而不是MySQL,可以从类似的线程中看到这个答案。