我尝试执行以下命令:
su -l user1 -c "hive -e \"ALTER TABLE schema1.table1 DROP IF EXISTS PARTITION (att1=\"$val\");\""我得到了错误:
FAILED: ParseException line 1:81 cannot recognize input near 'val1' ')' '<EOF>' in constant所以这里的问题是由于第二层嵌套的双引号,其间有一个值为val1的变量$val。
你能帮我解决吗?最好的办法是给我一个嵌套引号的规则。
发布于 2019-01-07 21:31:14
在这种特殊情况下,您可以使用单引号而不是内部(当前转义的)双引号,因为双引号中的单引号并不特殊。
su -l user1 -c "hive -e 'ALTER TABLE schema1.table1 DROP IF EXISTS PARTITION (att1=\"$val\");'"在一般情况下,您不能总是通过反斜杠转义来避免死亡。一般的引用规则非常简单;单引号之间的文本是逐字引用的,而双引号则较弱,但允许您对shell不应触及的内容进行反斜杠。
https://stackoverflow.com/questions/54073031
复制相似问题