微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何在shell脚本中将多个MySQL列提取到环境变量中?

我想从表中将一些数据提取shell脚本中的变量中.现在我做这样的事情:

export NAME=`MysqL -NB -e "select name from user where id = $ID"`
export AGE=`MysqL -NB -e "select age from user where id = $ID"`
export LOCATION=`MysqL -NB -e "select location from user where id = $ID"`

这很好,但我喜欢在一个查询中完成所有操作,例如:

select name, age, location from user where id = $ID

我尝试使用“read”这样:

MysqL -NB -e "select name, age, location from user where id = $ID" | read NAME AGE LOCATION
echo $NAME

…但它没有像我预期的那样工作(“echo”行没有输出).我错过了什么吗?

解决方法:

如果使用read in pipe,它将创建一个子shell并在此子shell中设置一个不影响父shell(您工作的地方)的变量.
一个主意:

export IFS=. ; set -- $(MysqL -N "select CONCAT_WS('.',name,age,location) from user where id=$ID")
NAME="$1" ; AGE="$2" ; LOCATION="$3"

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐