hive mysql 字符集_Hive字符编码

实验过程中发现把整个数据库编码改成latin1或者Utf8都不行,只有把整个数据库设定为latin1而把要存储中文的数据表的编码设定为UTF8才能够解决。

第一步:修改表字段的字符编码为utf8

修改字段注释字符集

alter table COLUMNS_V2 modify column COMMENT varchar(256) character set utf8;

修改表注释字符集

alter table TABLE_PARAMS modify column PARAM_VALUE varchar(4000) character set utf8;

修改分区表参数,以支持分区键能够用中文表示。

alter table PARTITION_PARAMS modify column PARAM_VALUE varchar(4000) character set utf8;

alter table PARTITION_KEYS modify column PKEY_COMMENT varchar(4000) character set utf8;

通过mysql命令:show create table COLUMNS_V2可以查看字段是否成功修改编码。

第二步:修改HiveJDBC的编码

javax.jdo.option.ConnectionURL

jdbc:mysql://IP:3306/hive?characterEncoding=UTF-8

JDBC connect string for a JDBC metastore

Ambari的配置位置:

0818b9ca8b590ca3270a3433284dd417.png

Hive-shell模式:set -v 可以查看配置是否成功。

AquaDataStudio(IDE)连接元数据的时候需要设置他的驱动如下:

0818b9ca8b590ca3270a3433284dd417.png

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值