我正在为客户清理用户数据库。我有需要删除的用户列表,并且正在检查他们是否有在删除之前创建的任何媒体。
这是一个非常简单的脚本,问题也相对较小。我确信这是显而易见的,我只是似乎无法弄清楚。
12 while read each;
13 do
14
15 query=$(mysql -u$username -p$password $database -e "select uid,nid,title from node where uid like '$each' limit 1;")
16 if [[ -z $query ]]
17 then query="No nodes"
18 fi
19 if [[ -z $query ]]
20 then query="Error"
21 fi
22 echo -n "$each"
23 echo -n " - "
24 echo "$query"
25 done <$source_file
我遇到的问题出现在第 22 行。我希望源文件中的每个 UID 各占一行,格式如下:
UID - Query results
我遇到的问题是,回显 $each
仅当它是该行的唯一参数时才有效。在上面的示例中,结果如下所示:
- Query results
(请原谅引用,但如果我不引用连字符,该论坛上的连字符将被解释为项目符号。)
如果我将多个变量或其他任何内容与第一个 echo 命令放在同一行,则 $each
变量将返回空。它只会显示变量的内容(如果它位于自己的行上),或者看起来是这样。
更多信息:
$each
变量是一个整数(从文件中读取)我如何解析它并不重要 - IE,如果我输入
newvar="$each - $query"
然后echo $newvar
同样的事情也会发生。上面有一个稍微误导性的评论。
echo "$each "
(带有尾部空格)会覆盖$each
中整数的一位数字。如果我将
echo -n "$each"
行放在代码的前面(在do
之后但在 mysql 查询之前),数字会显示在输出的底部,就像收报机磁带一样。这对我来说是迄今为止最奇怪的部分,如果有帮助的话我可以提供屏幕截图。
最佳答案
$each
末尾有一个 CR。在使用变量之前删除它。
关于mysql - Bash Echo 命令在 while 循环中表现异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28841233/