在 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个空格符去替换,这样可以规避上述问题。

相关推荐
阳爱铭2 小时前
ClickHouse 中至关重要的两类复制表引擎——ReplicatedMergeTree和 ReplicatedReplacingMergeTree
大数据·hive·hadoop·sql·clickhouse·spark·hbase
k***12172 小时前
从 SQL 语句到数据库操作
数据库·sql·oracle
w***37516 小时前
【SQL技术】不同数据库引擎 SQL 优化方案剖析
数据库·sql
--fancy6 小时前
如何使用Tushare构建自己的本地量化投研数据库
数据库·sql·数据分析
2501_941089198 小时前
5G技术与物联网的融合:智能城市与工业革命的加速器
spark
我科绝伦(Huanhuan Zhou)9 小时前
SQL进阶必备:从计算字段到多表联结,让查询效率翻倍!
数据库·sql
l1t13 小时前
利用DuckDB列表一句SQL输出乘法口诀表
数据库·sql·算法·duckdb
q***996314 小时前
SQL 中 COUNT 的用法详解
数据库·sql
wind_one114 小时前
9.基础--SQL--DML-插入
数据库·sql
float_六七14 小时前
SQL中=与IS的区别:关键用法解析
java·数据库·sql