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

时间:2016-02-24 02:15:46

标签: mysql database bash shell terminal

我尝试在脚本中使用此代码,但它只是创建了反引号中的内容。在这个例子中," 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

1 个答案:

答案 0 :(得分:20)

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

`table-db`

但是在bash中,它们具有不同的含义并用于command substitution。在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'`;'