昨天。。。客户要求,说要把数据库里的数据导出到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,此过程的作用为“以操作系统命令行解释器的方式执行给定的命令字符串,并以文本行方式返回任何输出。”下面为定义示例:
EXEC master..xp_cmdshell 'bcp 库名.dbo.表名out c:\Book3.xls -c -q -S"servername" -U"sa" -P""'
--参数:S 是SQL服务器名;U是用户名;P是密码,没有就空着
--说明:其实用这个过程导出的格式实质上就是文本格式的,不信的话在导出的Excel表中改动一下再保存看看。
实际例子与说明如下:
/**//*如果要将表整个导出至Excel的话*/
EXEC master..xp_cmdshell 'bcp northwind.dbo.orders out c:\Book1.xls -c -q -S"(local)" -U"sa" -P""'
--注意句中的northwind.dbo.orders,为数据库名+拥有者+表名
--直接导出用“out”关健字
-------------------------------------------
/**//*如果要利用查询来导出部分字段至Excel的话*/
EXEC master..xp_cmdshell 'bcp "SELECT orderid,cutomerid,freight FROM northwind..orders ORDER BY orderid" queryout C:\ Book2.xls -c -S"(local)" -U"sa" -P""'
--这里在bcp后面加了一个查询语句,并用双引号括起来
--利用查询要用“queryout”关键字
2、Excel导入SQL Server表:
在SQL Server中,有定义一个OpenDateSource函数,用于引用那些不经常访问的 OLE DB 数据源,而我们的数据互导操作,就是建立在这个函数之上。
首先看一个T-SQL帮助中的示例,描述如下:
EXEC master..xp_cmdshell 'bcp 库名.dbo.表名out c:\Book3.xls -c -q -S"servername" -U"sa" -P""'
--参数:S 是SQL服务器名;U是用户名;P是密码,没有就空着
--说明:其实用这个过程导出的格式实质上就是文本格式的,不信的话在导出的Excel表中改动一下再保存看看。
实际例子与说明如下:
/**//*如果要将表整个导出至Excel的话*/
EXEC master..xp_cmdshell 'bcp northwind.dbo.orders out c:\Book1.xls -c -q -S"(local)" -U"sa" -P""'
--注意句中的northwind.dbo.orders,为数据库名+拥有者+表名
--直接导出用“out”关健字
-------------------------------------------
/**//*如果要利用查询来导出部分字段至Excel的话*/
EXEC master..xp_cmdshell 'bcp "SELECT orderid,cutomerid,freight FROM northwind..orders ORDER BY orderid" queryout C:\ Book2.xls -c -S"(local)" -U"sa" -P""'
--这里在bcp后面加了一个查询语句,并用双引号括起来
--利用查询要用“queryout”关键字
2、Excel导入SQL Server表:
在SQL Server中,有定义一个OpenDateSource函数,用于引用那些不经常访问的 OLE DB 数据源,而我们的数据互导操作,就是建立在这个函数之上。
首先看一个T-SQL帮助中的示例,描述如下:
--下面是个查询的示例,它通过用于 Jet 的 OLE DB 提供程序查询 Excel 电子表格。
SELECT *
FROM OpenDataSource( 'Microsoft.Jet.OLEDB.4.0',
'Data Source="c:\Finance\account.xls";User ID=Admin;Password=;Extended properties=Excel 5.0')xactions
如果你直接引用这个示例进行查询,那么肯定是通不过的。关键在于语句中的两个地方需要修改,一处在于Data Source处,双引号内为Excel表格的实际存放位置,要修改为你想查询的Excel表实际完整路径;二为最后的...xactions,其实这里代表的是要进行的某些动作,下面会讲,这里修改成用中括号包围的Excel表中工作表名字(加上一个$)就可以了,如[Sheet1$]。当然,还可以将Excel 5.0改为Excel 8.0,因为5.0是以前的老版本了。
下面是实例说明:
/**//*1、插入Excel中的资料到现存的sql数据库表中(假设C盘有excel表book2.xls,book2.xls中有个工作表sheet1,sheet1中有两列id和FName;而同时sql数据库中也有一个表test):*/
insert into test SELECT id,FName
FROM OpenDataSource('Microsoft.Jet.OLEDB.4.0','Data Source="c:\book2.xls";User ID=Admin;Password=;Extended properties=Excel 8.0')[sheet1$]
--如果用select * ,则列的次序会乱,资料内容也会乱,无法插入成功,所以指定列名
-----------------------
/**//*2、插入excel表中资料到sql数据库并新建一个sql表(excel的定义和内容同上):*/
select convert(int,id)as id,FName into test7
FROM OpenDataSource('Microsoft.Jet.OLEDB.4.0','Data Source="c:\book2.xls";User ID=Admin;Password=;Extended properties=Excel 8.0')[sheet1$]
--在select 列中最好用convert进行显示类型转换,否则资料类型会不如预期。
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~
分享到:
相关推荐
此文档为代码,里面详细分析了SQL与Excel两者互导的过程。
从SQL Server中导入/导出 Excel 的基本方法及sql例子
基于ASP.NET的SQL与EXCEL数据互导的研究与实现.pdf
sqlserver定时器的设置,跨服务器的数据交接,里面有存储过程例子对A,B两个sqlserver服务器数据的互导,以及跨服务器需要设置的环境截图详解
mysql 与word和excel互导数据,运用sql语句实现,并且处理常出现的错误。
实现access与excel互相导入导出,代码详细完整
将数据库的数据导成Excel文件,将Excel文件导入数据库的小案例
JAVA实现mysql与excel数据互导 获得解压密码的方法 第一步:复制网址http://hijie.taobao.com到浏览器中 第二步:将打开的网页拉到最后,左下角复制解压密码
sql,access导出表结构,互导.
matlab与excel数据互导(秘籍).doc
JAVA实现mysql与excel数据互导Java实用源码整理learns.
实验1的在powerdesigner内建表,然后导入SQL中。
JAVA实现mysql与excel数据互导javalearnsa资料分享
vb编程,利用access数据库和excel数据互导,字段的excel的表格可选。可供选择、学习,参考。
可将excel文件的第二行以后的数据导致显示界面中,也可导出显示界面的数据至excel文件中
VB.Net2010Access与Excel互导(高清视频+源码).zip,由浅入深很容易明白,并且包含vb.net 编写的源代码,可以上机运行,希望对有需要的人有帮助,大家互相交流,互通有无。
ADO.Net助手是一个获取ADO.Net连接字符串(支持ADO.Net助手是一个获取ADO.Net连接字符串(支持Access,SQLite,SQLServer,MySQL和ORACLE),测试SQL命令,存储过程和数据库之间互导数据的辅助软件。ADO.Net助手还可以...
EXCEL,TXT文档数据和ORACLE数据互导的方法,可以把excel里的具体的数据导入到ORACLE里,也可以把ORACLE导出到excel
VS2010 + .net4.0 利用XML文件进行配置即可,涉及数据导入、数据导出、根据EXCEL修改SQL数据三个部分