【问题标题】:Declare variable in Bash?在 Bash 中声明变量?
【发布时间】:2011-07-20 09:00:59
【问题描述】:

我从 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的内容是什么? (echo $var)
  • 是的,我做了 echo $var,什么都没有,空白..
  • 您必须在一行中完成所有操作,因为没有导出变量:var=XmycommandX; echo $var(用反引号替换 X,我不知道如何逃避反引号评论框)。也使用-e 而不是管道。

标签: mysql bash shell variables


【解决方案1】:

更简单的方法是:

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

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

【讨论】:

    【解决方案2】:

    我认为您在管道中忘记了echo?像这样:

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

    【讨论】:

    • 好发现!还有一个理由根本不做任何管道,而是使用mysql -e
    猜你喜欢
    • 1970-01-01
    • 2015-03-14
    • 1970-01-01
    • 2020-08-14
    • 1970-01-01
    • 2010-11-21
    • 1970-01-01
    • 2014-04-10
    • 2013-03-24
    相关资源
    最近更新 更多