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

mysql – Bash脚本和行

我的问题是行mysql_query.
我需要:

Record 0: 2,text is text,3.23

但是我有

Record 0: 2
Record 1: text
Record 2: is
Record 3: text
Record 4: 3.23

请帮我.

results=($(MysqL --user root -proot test -Bse "select id,name from Object"));

cnt=${#results[@]}

for (( i=0 ; i<${cnt} ; i++ ))
do
    echo "Record No. $i: ${results[$i]}"

    fieldA=${results[0]};
    fieldB=${results[1]};

done

解决方法:

问题是您将MysqL输出存储到数组中.现在,如果MysqL返回多个记录,您将不知道记录何时结束而下一个记录开始,因为该数组将包含“扁平”数据,例如(record1_fieldA record1_fieldB record2_fieldA record2_fieldB …)

相反,使用while循环迭代记录,如下所示:

i=0
while read fieldA fieldB
do
    echo "Record $(( i++ )): fieldA: $fieldA fieldB: $fieldB"
done < <(MysqL --user root -proot test -Bse "select id,name from Object")

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

相关推荐