执行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 脚本可以正常运行了
总结
这个空格足足影响了半个小时的工作时间,看来刚睡醒确实需要精神一下,另外自己的脚本需要进行检查之后在运行。
分类:
工具
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· 一文读懂知识蒸馏
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下