设为首页 加入收藏

TOP

MYSQL5.1 WINDOWS环境下导出查询数据到EXCEL文件
2014-11-23 23:37:29 来源: 作者: 【 】 浏览:8
Tags:MYSQL5.1 WINDOWS 环境 导出 查询 数据 EXCEL 文件

今天做一个多表的联合查询,用phpmyadmin不支持导出,于是找到下面的方法,不错!

mysql查询出来的记录,导出到EXCEL文件,直接做报表输出。

测试环境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));
Query OK, 0 rows affected (0.00 sec)

mysql> insert into tt values(1,'北京','北京大学'),(2,'上海','上海大学'),(3,'深圳','深圳大学');
Query OK, 3 rows affected

Records: 3 Duplicates: 0 Warnings: 0

2:导出到EXCEL文件,用OUTFILE方法,下面2种方法的效果是一样的

mysql> select b,c from tt into outfile 'c:\xls_tt.xls';
Query OK, 3 rows affected (0.00 sec)

mysql> select b,c into outfile 'c:\xlstt.xls' from tt;
Query OK, 3 rows affected (0.00 sec)

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;
Query OK, 3 rows affected (0.00 sec)

打开导出的文件,一切都正常了。

EXCEL的默认编码方式是GB2312的,在查询出来的字段转换成DB2312后,双方达成一致,所以不再乱码。


闪电小子 blog

】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇批量生成sqlldr文件,高速卸载数据 下一篇mysql数据库同步debug

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: