我已从 bash 连接到我的数据库。我对一个数组进行了选择计数,我想将返回值存储在一个变量中。我该怎么做?
我做到了:
var=`"select count(*) from shop_tab where catalog <> ''" | mysql -h abcdcef.com --port=3306 --user=root --password=hbbfe shop`
请求返回一个数字,但它没有存储到变量中。
谢谢!
编辑:它适用于此命令行:
myvar = $(echo "select count(*) from shop_tab where catalog <> '';" | mysql -h abcdcef.com --port=3306 --user=root --password=hbbfe shop)
最佳答案
更简单的方法是:
var=$(mysql -h abcdcef.com --port=3306 --user=root --password=hbbfe --batch --skip-column-names -Dshop -e "select count(*) from shop_tab where catalog <> ''")
此外,我将预定义函数的使用,以便轻松地向 MySQL 命令添加选项,而无需修改所有脚本。
function MysqlQuery() {
mysql -h abcdcef.com --port=3306 --user=root --password=hbbfe --batch --skip-column-names -D "$1" -e "$2";
}
va=$(MysqlQuery Shop "SELECT COUNT(*) FROM shop_tab WHERE catalog <> ''")
vaABC=$(MysqlQuery Shop "SELECT COUNT(*) FROM shop_tab WHERE catalog <> 'abc'")
vadef=$(MysqlQuery Shop "SELECT COUNT(*) FROM shop_tab WHERE catalog <> 'def'")
# ...
我发现这也更具可读性......
关于mysql - 在 Bash 中声明变量?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6759397/