bash中返回变量的问题

时间:2011-07-20 14:42:14

标签: mysql bash shell return-value

这个mysql命令行返回我: count(*)19 。对我来说这是一个很大的问题,因为我只想 19 用这个数字做一个循环。我该怎么办?

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

3 个答案:

答案 0 :(得分:6)

更简单的方法是:

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 :(得分:2)

您可以使用awk或cut来获取第二个值。

<强> AWK

var = $(echo "select count(*) from shop_tab where catalog <> '';" | mysql -h abcdcef.com --port=3306 --user=root --password=hbbfe shop | awk '{ print $2 }')

<强>切

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

答案 2 :(得分:2)

通过tail管道结果以切断标题:

... shop | tail -1)