Hive drop table时出现 Error, return code 1 from org.apache.hadoop.hive.ql.exec.DDLTask. MetaException

在使用Hive的时候一直小心翼翼,因为对Hive掌握不够好,每次出错都要找半天才能找到错误所在,这次在删除一个表的时候,报了一个错:

FAILED: Execution Error, return code 1 from org.apache.hadoop.hive.ql.exec.DDLTask. MetaException(message:You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'OPTION SQL_SELECT_LIMIT=DEFAULT' at line 1)

查找网上的资料,总结为一下几点:

1.配置文件可能出错

2.mysql字符集的原因,可以通过在mysql中将数据库的字符集改为latin1,执行以下命令: 

           

 alter database hive character set latin1;

3.mysql-connector-java jar包版本不对,对应版本如下图,我的jar包本来是5.1.5,mysql为5.7版本,我以为jar包没有问题的,一直在找其他的解决方案,最后死马当活马医,换了一个5.1.32的jar包,没想到居然解决了这个问题。

另外最重要的一点就是学会查看日志,HIVE默认log文件保存的地方为:

/tmp/<user.name>文件夹的hive.log文件中,全路径就是/tmp/当前用户名/hive.log。

猜你喜欢

转载自blog.csdn.net/qq_41725214/article/details/86536312
今日推荐