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的问题。