MYSQL5.1 WINDOWS环境下导出查询数据到EXCEL文件
时间:2010-06-22 来源:909413335
测试环境WINDOWS XP,OFFICE 2003,MYSQL 5.1.45
1:创建一个测试表,3个字段,其中2个中文字段,用来做演示使用
mysql> create table tt(a int(11) not null,b varchar(30),c varchar(30)); Records: 3 Duplicates: 0 Warnings: 0 |
2:导出到EXCEL文件,用OUTFILE方法,下面2种方法的效果是一样的
mysql> select b,c from tt into outfile 'c:\xls_tt.xls'; |
3:到C盘下找到导出的XLS文件,发现都是乱码,如
鍖椾含 | 鍖椾含澶у? |
涓婃捣 | 涓婃捣澶у? |
娣卞湷 | 娣卞湷澶у? |
这样完全没办法使用。“这个时候文件是utf-8编码的,用excel打开,乱码。
把test.xls以文本方式打开,然后另存为,在编码选择ANSI编码,保存”。这样操作后,不乱码了,但是需要手工去处理。再看其他办法
4:通过网络朋友的帮忙,找到下面转换的方法
mysql> select convert(b using gb2312),convert(c using gb2312) into outfile 'c:\xlstt12.xls' from tt; |
打开导出的文件,一切都正常了。
EXCEL的默认编码方式是GB2312的,在查询出来的字段转换成DB2312后,双方达成一致,所以不再乱码。