解决Hive使用desc显示中文注释乱码

Hive数据库原生不支持中文注释的显示,使用desc命令,如果有中文就会显示乱码。解决方法如下

修改MySQL中的metadata

进入mysql ,查看hive 数据库当前编码

show create database hive ;
复制代码

如果是utf8 则执行下面sql将 hive 数据库默认编码改成 latin1

alter database hive default character set latin1 ;
复制代码

执行下面sql ,修改 表/字段/分区/索引 等部分的注释字符集

use hive; 
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;
alter table  INDEX_PARAMS  modify column PARAM_VALUE  varchar(4000) character set utf8;
复制代码

在Hive中验证

在hue或者beeline中执行hql

drop table if exists demo.cn_comment ;

CREATE TABLE IF NOT EXISTS demo.cn_comment (
    c1 STRING COMMENT 'this is english comment',
    c2 FLOAT COMMENT '中文注释'
) COMMENT '表-中文注释'
stored as orc;

desc demo.cn_comment;
复制代码

遗留问题

本文的方法仅能解决desc显示的问题,不能解决show create table xxx的问题。

转载于:https://juejin.im/post/5af670ebf265da0b7528307f

  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值