昨天。。。客户要求,说要把数据库里的数据导出到excel,没办法,以前没做过这个,只好去网上查资料
几经周折,终于找到了方法,不过是利用sql的存储过程来实现的。。。。。
以下是原文:
来自:http://www.cnblogs.com/bonny.wong/archive/2005/01/29/99387.html
**************************************************************************************************************
最近看到很多朋友在论坛上问SQL Server表与Excel、Access数据互导的问题,问题很简单,也很早就有人专门写文章讨论过这个问题,但看了那些文章,也没几个人讲得很明白,都是些很笼统的格式,估计初学者会被那些答案弄得稀里糊涂,更别说能学到新的东西。
基于这个原因,下面我将详细的讲解互导的过程,当然,常规的在SQL Server管理器中得用向导互导的过程我就不多讲了,下面讲的都是直接用T-SQL语句来实现的。
1、SQL Server导出为Excel:
要用T-SQL语句直接导出至Excel工作薄,就不得不用借用SQL Server管理器的一个扩展存储过程:xp_cmdshell,此过程的作用为“以操作系统命令行解释器的方式执行给定的命令字符串,并以文本行方式返回任何输出。”下面为定义示例:
实际例子与说明如下:
2、Excel导入SQL Server表:
在SQL Server中,有定义一个OpenDateSource函数,用于引用那些不经常访问的 OLE DB 数据源,而我们的数据互导操作,就是建立在这个函数之上。
首先看一个T-SQL帮助中的示例,描述如下:
实际例子与说明如下:
2、Excel导入SQL Server表:
在SQL Server中,有定义一个OpenDateSource函数,用于引用那些不经常访问的 OLE DB 数据源,而我们的数据互导操作,就是建立在这个函数之上。
首先看一个T-SQL帮助中的示例,描述如下:
如果你直接引用这个示例进行查询,那么肯定是通不过的。关键在于语句中的两个地方需要修改,一处在于Data Source处,双引号内为Excel表格的实际存放位置,要修改为你想查询的Excel表实际完整路径;二为最后的...xactions,其实这里代表的是要进行的某些动作,下面会讲,这里修改成用中括号包围的Excel表中工作表名字(加上一个$)就可以了,如[Sheet1$]。当然,还可以将Excel 5.0改为Excel 8.0,因为5.0是以前的老版本了。
下面是实例说明:
SQL Server与Excel的数据互导讲解完了,你明白了吗?而Access和Excel的基本一样,只是要去掉Extended properties声明。
**************************************************************************************************************
看了文章后,在sql的查询分析器里试着用了用,成功!小激动一下。。
可是问题并没有完全解决,我总不可能把sql语句发给客户,跟他说:你把这句语句复制到sql的查询分析器里执行下就好了。。。
汗一汗,然后找了下jsp以及java执行存储过程的资料,找到了不少,不过大多都是执行oracle的例子。
不过没事,反正执行方法是差不多的。然后分析了下那些例子。。。结果开始迷糊了,按上面存储过程的说法,我执行的语句中还要分析参数bcp,out,queryout等的参数。。。。给出的例子似乎简单了点。。。于是登陆ITPUB上去提问。。。结果人家大虾同志又给了一个oracle的例子。。
头大了。。。然后。。又提出了我的疑惑。。之后睡觉。。。
今天中午前再次登陆ITPUB,结果发现。。。问题的末帖还是我昨晚自己的帖子。。。。
没办法了,只好自己一点点来try了
然后我才发现我真的是很笨。。。其实早就应该自己试试看了。。。试过后才发现,其实根本不用担心参数的问题,直接把它们代入变量就可以了。。。汗阿
具体执行方法:
String pro="{call master..xp_cmdshell (?)}";
CallableStatement cstmt = conn.prepareCall(pro);
String table="DGL.dbo.product";
String path="C:\\test1.xls";
cstmt.setString(1,"bcp "+table+" out "+path+" -c -q -S\"(local)\" -U\"sa\" -P\"\"");
cstmt.execute();
语句中的反斜杠和双引号只要用反斜杠来转义掉,问题就ok了,我之前就是这一关没想到,以为要另外定义参数。。。结果就这么死在这里。。。幸好今天早上想到了。。HOHO~