Bash for loop:反引号

时间:2016-01-25 06:59:50

标签: mysql bash backticks

我有这段代码

$db=test-1
for T in `mysql -u$dbUser -p$dbPass -N -B -e 'show tables from '$db`;
do
count=$((count+1))
mysqldump --skip-comments --compact --skip-lock-tables -u$dbUser -p$dbPass $db $T > $GIT_MYSQL/$T.sql
done
done;

它给了我这个错误

  

第1行的错误1064(42000):您的SQL语法出错;检查与您的MySQL服务器版本对应的手册,以便在#" -1'附近使用正确的语法。在第1行

我该如何解决?

1 个答案:

答案 0 :(得分:2)

您未正确声明数据库名称变量。试着这样做:

$db=test-1
echo "My database is called $db"

将输出与此进行比较:

db=test-1
echo "My database is called $db"

考虑到上述评论和正确(我希望)引用,您的脚本应该可以正常工作:

dbUser="user"
dbPass="pass"
db="test-1"
for T in $(mysql -u "$dbUser" -p"$dbPass" -N -B -e "show tables from $db")
do
    mysqldump --skip-comments --compact --skip-lock-tables -u "$dbUser" -p"$dbPass" "$db" "$T" > "$GIT_MYSQL/$T.sql"
done