在安装Hive时,经常报异常。
后来采用输出日志的方式来开启hive:hive -hiveconf hive.root.logger=DEBUG,console
这样在执行命令时,就会输出日志,出现异常可以很快定位。
ERROR DataNucleus.Datastore: Error thrown executing CREATE TABLE SD_PARAMS
(
SD_ID BIGINT NOT NULL,
PARAM_KEY VARCHAR(256) BINARY NOT NULL,
PARAM_VALUE VARCHAR(4000) BINARY NULL,
CONSTRAINT SD_PARAMS_PK PRIMARY KEY (SD_ID,PARAM_KEY)
) ENGINE=INNODB : Specified key was too long; max key length is 767 bytes
com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: Specified key was too long; max key length is 767 bytes
这是字符集的问题,在数据库上执行 alter database hive character set latin1;来修改字符集,问题解决。
由于正常的情况,为了防止出现乱码,我们需要 将其设置为utf-8.
搭建 hive mysql 的步骤 建议按照以下三步:
1)新配置hive的时候,不要去设定编码为utf8,让hive自动新建mysql中的数据库hive(这点特别重要)。
2)检查发现hive库已经建成的时候