Вопрос переписан:MySQL создать базу данных и пользовательский сценарий
HOMEDIR="ftpuser"
REMOTEIP="1.1.1.1"
MYSQLPASS="password"
Q1="DROP USER "$HOMEDIR"_shop;"
Q2="DROP DATABASE "$HOMEDIR"_shop;"
Q3="CREATE DATABASE IF NOT EXISTS "$HOMEDIR"_shop;"
Q4="GRANT ALL ON "$HOMEDIR"_shop TO '"$HOMEDIR"_shop'@'localhost' IDENTIFIED BY '$MYSQLPASS';"
Q5="GRANT ALL ON "$HOMEDIR"_shop TO '"$HOMEDIR"_shop'@'anotherip' IDENTIFIED BY '$MYSQLPASS';"
# Need to grant permissions from another server as well
Q6="FLUSH PRIVILEGES;"
SQL="${Q1}${Q2}${Q3}${Q4}${Q5}${Q6}"
echo $SQL
echo " "
ssh -p 8899 [email protected]$REMOTEIP "mysql -u root -p "$SQL""
Я затем запустить:
/root/testing/migratesite.sh
И получите:
bash: DROP: command not found
bash: CREATE: command not found
bash: GRANT: command not found
bash: GRANT: command not found
bash: FLUSH: command not found
Что мне не хватает?
работает для меня, MySQL 5.0.51, 3.2.39 BASH. Вы используете его внутри другого скрипта? Это выполняется, если вы запускаете его через командную строку? –
Я переделал свой вопрос, чтобы объяснить, что я делаю, а не то, что я основываю на нем! Надеюсь, это поможет! – Lizard
Я бы сказал, что это 'ssh -p 8899 root @ $ REMOTEIP" mysql -u root -p $ SQL "" 'не может работать из-за кавычек ... но у меня нет машины, чтобы попробовать но еще ... попытайтесь избежать котировок вокруг $ SQL. – Bobby