由于业务需要早上修改了一个固定需求加工逻辑的一个子查询,把修改后的 hivesql 封装成 shell 脚本后执行报错了,运行脚本最后一行提示如下:
t1.service_type;: bad substitution
经过查询了解到 bad substitution的字面意思,它的字面意思是“替换错误”的意思。这种错误的原因呢,通常是我们编写脚本时“{}”和“()”错误使用导致的。比如应该用“()”时,我们用成了“{}”;应该用“()”时,用成了“{}”。那么如何区分什么时候用什么类型的括号呢?${}中,大括号里放的是变量;$(commamd)里是执行command(即我们的命令或者一些运算),然后用它的输出代替$()。
where month_id = '${month_id }'
原来这里引入变量的时候多了一个空格,修改如下
where month_id = '${month_id}'
shell 脚本可以正常运行了
这个空格足足影响了半个小时的工作时间,看来刚睡醒确实需要精神一下,另外自己的脚本需要进行检查之后在运行。