shell中執行hive命令錯誤:delimited by end-of-file (wanted `EOF')


錯誤信息:

warning: here-document at line 58 delimited by end-of-file (wanted `EOF')

 

業務場景,使用hive對數據進行批量清洗,hive語句放到shell腳本中方便執行。

#定義hql
sql=$(cat <<!EOF
hive的hql語句塊
!EOF)
#執行hql
$HIVE_HOME/bin/hive -e "$sql"

以上代碼執行時總是出現警告信息, 這里的EOF結束標記有問題。

注意: 結束標記的前后不要有空格等其他符號,所以獨立寫成一行就可以了。

修改后如下:

#定義hql
sql=$(cat <<!EOF
hive的hql語句塊
!EOF
)
#執行hql
$HIVE_HOME/bin/hive -e "$sql"

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM