gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-11-29 12:22:13 27 4
gpt4 key购买 nike

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

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

 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/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com