如何在 ubuntu 中使用脚本添加带有连字符的数据库名称

问题描述 投票:0回答:2

我尝试在脚本中使用此代码,但它只是创建了反引号内的内容。在此示例中,在数据库中创建了“echo "table-db"”。它没有创建查询中带有连字符的文件夹名称

hyph=`ls -l $DBDIR | egrep '^d' | grep '.-.' | awk '{print $9}'`

dbhype=($hyph)


for dbtry in ${!dbhype[*]}
   do            
        mysql -u$dbUser -p$dbPass -e 'CREATE DATABASE IF NOT EXISTS `echo "table-db"` CHARACTER SET utf8 COLLATE utf8_general_ci';

        echo "Database ${dbhype[$dbtry]} created."

done
mysql database bash shell terminal
2个回答
78
投票

在 mysql 查询表名中可能包含字母数字字符、下划线和美元符号。为了能够使用其他 ANSI 字符,您必须将名称放在单反引号中。

`table-db`

但在 bash 中它们有不同的含义并用于 命令替换。在 bash 中还有多种类型的字符串——双引号和单引号。它们之间的区别在于,在双引号中执行变量扩展和命令替换,而在单引号中则不执行。因此,您可以按原样在单引号内使用带有 mysql 语义的反引号

mysql -e 'CREATE DATABASE `table-db`;'

但在双引号内使用时必须转义它们,这样它们就不会被 bash 解释为命令替代。

mysql -e "CREATE DATABASE \`table-db\`;"

当您想从变量中获取数据库名称时,您需要将其放在单引号字符串之外,如下所示:

mysql -e "CREATE DATABASE \`$dbname\`;"

或者像这样:

mysql -e 'CREATE DATABASE `'$dbname'`;'

0
投票

有一个类似的问题,但我的数据库名称中带有 - ,因此我无法安装 mod

if (strpos($db_name, '.') === false)
    $result = $smcFunc['db_query']('', "
        SHOW TABLE STATUS FROM {raw:db_name}",
        array('db_name' => $db_name)
    );
else

给我错误 数据库错误:您的 SQL 语法有错误;检查与您的 MariaDB 服务器版本相对应的手册,了解在第 1 行“-353036339dae”附近使用的正确语法

© www.soinside.com 2019 - 2024. All rights reserved.