mysql - Bash Echo 命令在 while 循环中表现异常

标签 mysql bash variables while-loop echo

我正在为客户清理用户数据库。我有需要删除的用户列表,并且正在检查他们是否有在删除之前创建的任何媒体。

这是一个非常简单的脚本,问题也相对较小。我确信这是显而易见的,我只是似乎无法弄清楚。

 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 变量将返回空。它只会显示变量的内容(如果它位于自己的行上),或者看起来是这样。

更多信息:

  1. $each 变量是一个整数(从文件中读取)

  2. 我如何解析它并不重要 - IE,如果我输入 newvar="$each - $query" 然后 echo $newvar同样的事情也会发生。

  3. 上面有一个稍微误导性的评论。 echo "$each "(带有尾部空格)会覆盖 $each 中整数的一位数字。

  4. 如果我将 echo -n "$each" 行放在代码的前面(在 do 之后但在 mysql 查询之前),数字会显示在输出的底部,就像收报机磁带一样。这对我来说是迄今为止最奇怪的部分,如果有帮助的话我可以提供屏幕截图。

最佳答案

$each 末尾有一个 CR。在使用变量之前删除它。

关于mysql - Bash Echo 命令在 while 循环中表现异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28841233/

相关文章:

python - 了解如何使用 Bash 和/或 Biopython 管理表格数据(BLAST+6 格式)的资源

bash 完成 : description text when pressing TAB (sort of heredoc for autocompletion)

linux - 脚本中的 cp 不适用于 incron?

java - 多次调用函数或创建变量

php - 如何在 Yii2 中连接到远程 mySQL 数据库

mysql - 检查存储过程中的 var 是否为 NULL

javascript 变量未设置 - 通过 Firebug 检查

sql - 在 SQL 中构造 FROM

mysql - Perl 脚本无法在 @INC 中找到 Text/Template.pm

php - 从 Propel 的结果集中排除连接关系对象的方法?