在 spark-sql / spark-shell / hive / beeline 中粘贴 sql、程序脚本时的常见错误

一个很小的问题,简单记录一下。有时候我们会粘贴一段已经成功运行过的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个空格符去替换,这样可以规避上述问题。

相关推荐
engchina14 小时前
自然语言转 SQL 并不是“魔法”
数据库·人工智能·sql·text2sql·nl2sql·自然语言转sql
BD_Marathon15 小时前
动态SQL(六)foreach标签2
数据库·sql
IT大白15 小时前
1、一条SQL是如何执行的
数据库·sql
独自破碎E16 小时前
MySQL中如何进行SQL调优?
数据库·sql·mysql
一名机电研究生17 小时前
电机驱动系统智能监测与故障预测技术指南:构建数据驱动的预防性维护体系
python·sql·诊断预测
拾起零碎18 小时前
U8/对比一级科目,快速判断需要调整的报表
sql
l1t19 小时前
净化SQL的PL/pgSQL函数
数据库·sql·postgresql
Hello.Reader19 小时前
Flink MongoDB SQL Connector Scan/Lookup/Sink 全打通,Upsert、分片集群与缓存一篇讲透
sql·mongodb·flink
Mr_Xuhhh19 小时前
存储过程和触发器的总结
sql
熬夜敲代码的小N20 小时前
MySQL数据可视化实战:从SQL雕琢到图表绽放
sql·mysql·信息可视化