姜小嫌

  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

Specified key was too long; max key length is 767 bytes 此错误为hive 元数据mysql 字符集编码问题
如 show create table PARTITIONS ;
utf-8会报上述错误。
要把CHARSET=utf-8 修改为 CHARSET=latin1;

 alter table PARTITIONS convert to character set latin1;

所以最好在hive 建库之初就设置好字符集编码

 alter database hivedb character set latin1;

这样就万事大吉了,再启动hive metastore 服务 所有的表都为 latin1编码了。
但是如果先启动了 metastore 服务,这样hivedb 中所有的表都是utf-8了(当然这根数据库的配置有关)。
这样你再执行 alter database hivedb character set latin1; 就晚了。元数据表已经创建完毕了,都是utf-8了。
所以你要把hivedb 中所有的表都修改一遍

 alter table table_name convert to character set latin1;
posted on 2018-10-29 17:49  姜小嫌  阅读(389)  评论(0编辑  收藏  举报