Chinaunix首页 | 论坛 | 博客
  • 博客访问: 235383
  • 博文数量: 37
  • 博客积分: 325
  • 博客等级: 一等列兵
  • 技术积分: 1199
  • 用 户 组: 普通用户
  • 注册时间: 2012-06-09 00:04
个人简介

坚持原创,虽然有些东西很简单,但也算是一种积累。

文章分类

全部博文(37)

文章存档

2013年(28)

2012年(9)

我的朋友

分类: Mysql/postgreSQL

2013-05-11 23:35:54

    有个项目采用mysql 数据库,因历史原因库中有编码为latin1的表,现需要统一转换为utf8并保留原表内容。单纯修改表编码无法满足需求,结合shell 可高效完成此任务。以下本人所用的方法及部份实现代码--有更好办法请留言。个人直接用dump出来再转utf8会乱码。
采用into outfile 倒出表记录
   select * from table into outfile '/tmp/file';  
结合shell 获取latin1编码的表
mysql -h$dbhost -u$dbuser -p$dbpass -D${dbbash_u}  <table_char 
show table  status;
SHOW
#取出表,字符编码
awk '{print$1,$16}' table_char  >char
#取出latin
grep 'latin1' char  >table_latin1
接着
对属于latin1表进行for处理
count_latin1=`wc -l  table_latin1  |awk '{print$1}'`
    for (( i=1;i<=${count_latin1};i++ ));
        do
            echo $i
            l_table=`sed -n  ''$i'p' table_latin1 |awk '{print$1}'`
            echo "开始导$l_table表"
            mysql -h$dbhost -u$dbuser -p$dbpass -D${dbbash_u} <
            select * from $l_table into outfile '/tmp/outfile/latin/${l_table}_outfile_latin1';
INTO
        done
接着:将latin1格式文件转换成utf8:
最后:将转换后的数据批量导回对应的表:
for (( i=1;i<=${count_latin1};i++ ));
        do
        echo $i
        l_table=`sed -n  ''$i'p' table_latin1 |awk '{print$1}'`
        echo "开始导$l_table表"
        mysql -P3307 -h$dbhost_u -u$dbuser -p$dbpass -D${dbbash_u} <
        delete from $l_table;
        load data infile '/tmp/outfile/latin/${l_table}_outfile_utf8'  into table  ${l_table};
INTO
        done
echo "latin导入完成"

阅读(4198) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~