hive中文注释乱码解决方案(只针对新建表)

 当中文comment出现?乱码时

①在Hive元数据存储的Mysql数据库中,执行以下SQL:

#修改字段注释字符集
alter table COLUMNS_V2 modify column COMMENT varchar(256) character set utf8;
#修改表注释字符集
alter table TABLE_PARAMS modify column PARAM_VALUE varchar(20000) character set utf8;
#修改分区参数,支持分区建用中文表示
alter table PARTITION_PARAMS modify column PARAM_VALUE varchar(20000) character set utf8;
alter table PARTITION_KEYS modify column PKEY_COMMENT varchar(20000) character set utf8;
#修改索引名注释,支持中文表示
alter table INDEX_PARAMS modify column PARAM_VALUE varchar(4000) character set utf8;
#修改视图,支持视图中文
ALTER TABLE TBLS modify COLUMN VIEW_EXPANDED_TEXT mediumtext CHARACTER SET utf8;
ALTER TABLE TBLS modify COLUMN VIEW_ORIGINAL_TEXT mediumtext CHARACTER SET utf8;

②修改hive-site.xml中Hive读取元数据的编码

 
    javax.jdo.option.ConnectionURL
    jdbc:mysql://localhost:3306/metastore?useSSL=false&useUnicode=true&characterEncoding=UTF-8

ps:别忘了localhost替换为自己的主机映射名。

 

此修改只对新建的库或表有效,旧的表还是乱码状态,上面是删表重建的。

表少的话可以通过修改表的列属性来修正乱码:

ALTER TABLE 表名 change column 列名 新列名 属性 COMMENT  '内容' ;

例如:ALTER TABLE test_table change column name name STRING COMMENT '姓名';

表太多就太麻烦了。


本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!

相关文章

立即
投稿

微信公众账号

微信扫一扫加关注

返回
顶部