执行shell脚本文件提示: bad substitution

问题描述

由于业务需要早上修改了一个固定需求加工逻辑的一个子查询,把修改后的 hivesql 封装成 shell 脚本后执行报错了,运行脚本最后一行提示如下:

       t1.service_type;: bad substitution

问题分析

经过查询了解到 bad substitution的字面意思,它的字面意思是“替换错误”的意思。这种错误的原因呢,通常是我们编写脚本时“{}”和“()”错误使用导致的。比如应该用“()”时,我们用成了“{}”;应该用“()”时,用成了“{}”。那么如何区分什么时候用什么类型的括号呢?${}中,大括号里放的是变量;$(commamd)里是执行command(即我们的命令或者一些运算),然后用它的输出代替$()

问题解决

今天修改的两个子查询中确实有一个引入了外部变量

    where month_id = '${month_id }'

原来这里引入变量的时候多了一个空格,修改如下

    where month_id = '${month_id}'

shell 脚本可以正常运行了

总结

这个空格足足影响了半个小时的工作时间,看来刚睡醒确实需要精神一下,另外自己的脚本需要进行检查之后在运行。

posted @ 2022-09-06 06:34  晓枫的春天  阅读(1995)  评论(0编辑  收藏  举报