如何在bash脚本中授予MySQL权限?

Dun*_*ril 4 mysql linux bash shell grant

我需要从bash脚本中为数据库授予权限.有些参数是变量形式,比如用户名和密码.mysql shell中的命令如下所示:

GRANT ALL ON *.* TO "$user"@localhost IDENTIFIED BY "$password";
Run Code Online (Sandbox Code Playgroud)

......除了$user$password将它们的值来代替.

有没有办法在bash脚本中执行这样的命令?

谢谢!

Jau*_*ika 7

你去:)

#!/bin/bash

MYSQL=`which mysql`
EXPECTED_ARGS=3

Q1="USE $1;"
Q2="GRANT ALL ON *.* TO '$1'@'localhost' IDENTIFIED BY '$2';"
Q3="FLUSH PRIVILEGES;"
SQL="${Q1}${Q2}${Q3}"

if [ $# -ne $EXPECTED_ARGS ]
then
  echo "Usage: $0 dbname dbuser dbpass"
  exit $E_BADARGS
fi

$MYSQL -uroot -p -e "$SQL"
Run Code Online (Sandbox Code Playgroud)