131*_*2EN 11 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
Run Code Online (Sandbox Code Playgroud)
use*_*246 26
在mysql查询中,表名可能包含字母数字字符,下划线和美元符号.为了能够使用其他ANSI字符,您必须将名称放在单个反引号中.
`table-db`
Run Code Online (Sandbox Code Playgroud)
但是在bash中,它们具有不同的含义并用于命令替换.在bash中还有几种类型的字符串 - 双引号和单引号.它们之间的区别在于,在双引号中执行变量扩展和命令替换,而在单引号中则不执行.所以你可以在单引号中使用带有mysql语义的反引号
mysql -e 'CREATE DATABASE `table-db`;'
Run Code Online (Sandbox Code Playgroud)
但是当在双引号内使用时必须逃避它们,这样它们就不会被bash解释为命令替换.
mysql -e "CREATE DATABASE \`table-db\`;"
Run Code Online (Sandbox Code Playgroud)
由于您希望从变量中获取数据库名称,因此需要将其置于单引号字符串之外,如下所示:
mysql -e "CREATE DATABASE \`$dbname\`;"
Run Code Online (Sandbox Code Playgroud)
或者像那样:
mysql -e 'CREATE DATABASE `'$dbname'`;'
Run Code Online (Sandbox Code Playgroud)