在Bash中声明变量?

时间:2011-07-20 09:01:00

标签: mysql bash shell variables

我从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)

2 个答案:

答案 0 :(得分:4)

更简单的方法是:

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'")
# ...

我觉得这也更具可读性......

答案 1 :(得分:1)

我认为你忘记了管道中的echo?像这样:

var=`echo "select count(*) from shop_tab where catalog <> ''" | mysql -h abcdcef.com --port=3306 --user=root --password=hbbfe shop`