一个很小的问题,简单记录一下。有时候我们会粘贴一段已经成功运行过的SQL或程序脚本,但是在spark-sql / spark-shell / hive / beeline 中执行时可能会报这样的错误:
bash
hive> CREATE EXTERNAL TABLE IF NOT EXISTS ORDERS(
> Display all 641 possibilities? (y or n)
! != $ELEM$ $KEY$
... ... ...
... ... ...
输出的Display all 641 possibilities? (y or n)
信息在暗示我们:脚本中有tab建,这会让某些shell终端解析为"寻求代码提示",所以才会给出Display all 641 possibilities? (y or n)
这样的信息。我们可以在文本编辑器,例如notepad++,中选择"视图" -> "显示符号" -> "显示空格与制表符" 来确认是否在脚本中含有tab字符。
相应的解决方法是:使用空格(4个或2个)查找替换tab字符即可。
PS. 可能也是因为这种原因,现在IDE(例如IntelliJ)已经不使用Tab键作为代码缩进了,而是改用4个或2个空格符去替换,这样可以规避上述问题。