hive mysql元数据,报错 Specified key was too long; max key length is 767 bytes

本文解决Hive元数据存储在MySQL时因字符集编码引发的错误:Specified key was too long; max key length is 767 bytes。通过将CHARSET=utf-8修改为CHARSET=latin1,避免元数据表创建时出现长度限制问题。

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;

945048-20181029175033393-299193318.png

所以最好在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 姜小嫌 阅读( ...) 评论( ...) 编辑 收藏

转载于:https://www.cnblogs.com/jiangxiaoxian/p/9872046.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值