未加星标

MySQL实现导出excel的方法分析

字体大小 | |
[数据库(mysql) 所属分类 数据库(mysql) | 发布者 店小二03 | 时间 | 作者 红领巾 ] 0人收藏点击收藏

本文实例讲述了mysql实现导出excel的方法。分享给大家供大家参考,具体如下:

MySQL 要导出成 excel 文件很简单,执行类似这样的命令:

select * from 某个表 into outfile 'd:/文件名.xls';

上述命令你在服务器上执行,就导在服务器 D: 盘,若在客户端命令行方式执行,就导在客户端 D:盘 ,若在客户端通过 POST 方式执行,则导在服务器 D:盘。能导成功的大前提是你有登录权限,要有 select 权限,而且还要有 file 权限,如果没有 file 权限,你将无法执行 select....into outfile 和 load data infile .... 之类的操作。

至于加一个按钮,点击一下提示保存为 excel 文件,我想你可能指的是在网页上吧?如果在网页上,对 MySQL 的操作一般被屏蔽在后面了,一般都是通过服务器端脚本语言php,JSP,ASP之类的)去操作 MySQL,下面分别以 PHP 和javascript 为例,将数据库查询结果保存为 xls 的方法(两种办法我都实践过,是可行的):

1.PHP 方法:

调用 header() 函数,参数如下:

header("content-type:application/msexcel");
header("content-disposition:filename=file001.xls");

这两个函数放在 PHP 文件中执行数据库查询操作之前。

一般,数据库查询操作结束后,可通过 echo(),printf() 之类的函数将查询结果展示给客户端,如果在执行数据库操作之前加了上述两行,则客户端将不再显示结果,而是出现一个下载并保存为 xls的对话框,路径与文件名可以自由选择。按钮<input type=button ...> 或链接<a href=...>你可以放在第 1 页,将其指向第2页,第1页用来向客户端显示结果,第2页(PHP文件)放上上述两行,然后写上连接数据库并执行与第1页相同的查询操作的代码。这样你在第1页上点击此链接就会跳出一个下载并保存为 xls 的对话框,保存的内容就是你在第 1 页上看到的查询结果,保存格式为 xls,保存后你可用 Excel 打开它进行操作。

PHP 是服务器端脚本,用上述办法实际上同样的数据结果从服务端向客户端传了两次,第一次用来显示,第二次用来打包成 xls 文件供下载。

2.JavaScript 方法:

首先在数据所在页面的 <head> 部分定义一个 JS 函数:

<head>
<script language="javascript">
function xSaveAsxls( xResult , xFileName ){
var ow=window.open();
with(ow){
document.write(Result);
document.execCommand('Saveas', true, xFileName);
close();
}
}
</script>
</head>

然后在展示数据的 <table> 之前放上 <div id=div_id>,在</table>之后放上</div>。

然后在下面做一个按钮:

<input type="button" value="保存为 Excel 文件" onclick=xSaveAsxls
(document.all.div_id.innerHTML,'filename.xls')>

这样就行了,这个显示为“保存为 Excel 文件”,你点击它就弹出一个保存对话框,保存的内容就是数据结果集,格式为 xls 。

JS 是浏览器端脚本,用这种办法将显示结果保存为 xls ,其数据从服务器向客户端只传一次,节省传输资源。

另外还有一种办法就是考虑将查询结果集由 PHP 传递给 JS 数组变量,由其带到客户端,然后调用FileObjectSystem 进行操作,这只是个思路,我没去实践过。

不当之处请指正。

如果有乱码问题:可以使用如下语句

select convert(dname using gb2312),email from d_dealerinfo into outfile 'd:/d.xls';

其中dname 是中文的

更多关于MySQL相关内容感兴趣的读者可查看本站专题:《MySQL查询技巧大全》、《MySQL事务操作技巧汇总》、《MySQL存储过程技巧大全》、《MySQL数据库锁相关技巧汇总》及《MySQL常用函数大汇总》

希望本文所述对大家MySQL数据库计有所帮助。


您可能感兴趣的文章:PHP导出MySQL数据到Excel文件(fputcsv)Mysql中文乱码以及导出为sql语句和Excel问题解决方法[图文]mysql 导出select语句结果到excel文件遇到问题及解决方法PHP导入Excel到MySQL的方法使用phpexcel类实现excel导入mysql数据库功能(实例代码)Excel数据导入Mysql数据库的实现代码PHP上传Excel文件导入数据到MySQL数据库示例php 将excel导入mysqlphpMyAdmin下将Excel中的数据导入MySql的图文方法php通过PHPExcel导入Excel表格到MySQL数据库的简单实例php导入excel文件到mysql数据库的方法

本文数据库(mysql)相关术语:navicat for mysql mysql workbench mysql数据库 mysql 存储过程 mysql安装图解 mysql教程 mysql 管理工具

主题: MySQLSQLPHP服务器数据JavaScriptJavaExcelHTMLJSP
tags: MySQL,gt,lt,xls,Excel,PHP,excel,数据库,客户端,导入,保存,select,文件,查询,div
分页:12
转载请注明
本文标题:MySQL实现导出excel的方法分析
本站链接:https://www.codesec.net/view/574980.html


1.凡CodeSecTeam转载的文章,均出自其它媒体或其他官网介绍,目的在于传递更多的信息,并不代表本站赞同其观点和其真实性负责;
2.转载的文章仅代表原创作者观点,与本站无关。其原创性以及文中陈述文字和内容未经本站证实,本站对该文以及其中全部或者部分内容、文字的真实性、完整性、及时性,不作出任何保证或承若;
3.如本站转载稿涉及版权等问题,请作者及时联系本站,我们会及时处理。
登录后可拥有收藏文章、关注作者等权限...
技术大类 技术大类 | 数据库(mysql) | 评论(0) | 阅读(83)