Я новый пользователь в переполнении стека, поэтому заранее прошу прощения за любые потенциальные нарушения этикета сайта.
Я пытаюсь создать скрипт BASH, который сгенерирует команду для вызова монитора MariaDB,то есть mysql
. Я хочу, чтобы эта команда mysql
включала параметр --init-command
. Я хочу, чтобы опция --init-command
установила список пользовательских переменных в их значения, как указано в файле конфигурации.
Сценарий создает строку, которая, по-видимому, подходит для моих целей, но при вызовеmysql
, сгенерирована ошибка. Если я распечатываю сгенерированную строку из скрипта, то, похоже, это именно то, что я пытался создать.
Я свел ее к следующему примеру кода:
#!/bin/sh
declare foo="name"
declare bar="value"
declare invoke="mysql -p -D information_schema"
declare opts=" --init-command='SET @$foo:=\"$bar\"'"
invoke+=$opts
echo $invoke
$invoke
КогдаЯ выполняю этот скрипт, результат выглядит так:
$ example.sh
mysql -p -D information_schema --init-command='SET @name:="value"'
Enter password:
ERROR 1044 (42000): Access denied for user 'Bill'@'%' to database '@name:="value"''
Это сообщение об ошибке даже не имеет смысла.
Однако, если я скопирую сгенерированную команду и вставлю ее обратнов командной строке он запрашивает мой пароль и поступает так, как я ожидал, следующим образом:
$ mysql -p -D information_schema --init-command='SET @name:="value"'
Enter password:
Welcome to the MariaDB monitor. Commands end with ; or \g.
Your MariaDB connection id is 171
Server version: 10.3.11-MariaDB Source distribution
Copyright (c) 2000, 2018, Oracle, MariaDB Corporation Ab and others.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
MariaDB [information_schema]> SELECT @name;
+-------+
| @name |
+-------+
| value |
+-------+
1 row in set (0.000 sec)
MariaDB [information_schema]>
демонстрация того, что команда SET
в опции --init-command
была успешно передана на монитор MariaDB,и выполнено.
Я не знаю, является ли это проблемой Linux, проблемой BASH или проблемой MariaDB. Итак, хотя я потратил много времени, пытаясь найти ответ, я действительно не знаю, откуда возникла проблема, и, следовательно, где сосредоточить свое исследование.
Обратите внимание: я использовал толькоБаза данных information_schema в моем примере, потому что я ожидаю, что любой, кто попытается воссоздать эту проблему, получит эту базу данных для себя.
Заранее благодарю за помощь.