sql2000 导入数据 (execl) 对所指定的缓冲区来讲太大的点解决方法

内容说明,本人将ecshop中的产品表的内容跟字段导出为execl后,将execl导入sql2000中,用了以下的方法,只需要一句将整个表的内容都创建了,同时也不会有字段数据长度的限制了(个人操作过的,至于内容的完整性未考究过),但这个方法也是一个解决缓冲区来讲太大的问题解决办法之一吧,希望对大家有用,同时有问题存在请大家指正下

微软的官方文章http://support.microsoft.com/kb/321686/zh-cn 。再加上自己的心得体会

1、分布式查询方式

将数据导入到一个新的表(注意execl的格式问题,ecshop导出的不合sql2000的,可以将sql2000的随便的一个导出一个execl,用这个execl的格式文件就可以了)

SELECT * INTO excel_import FROM OPENROWSET('Microsoft.Jet.OLEDB.4.0',
'Excel 8.0;Database=C:\excel_import.xls', 'SELECT * FROM [sheet1$]')

将数据导入到已经存在的表

insert into excel_import select * from  OPENROWSET('MICROSOFT.JET.OLEDB.4.0'  ,
     'Excel 5.0;HDR=YES;DATABASE=c:\import2.xls',sheet1$);

2、链接服务器方式

将excel建立链接服务器:

DECLARE @RC int
DECLARE @server nvarchar(128)
DECLARE @srvproduct nvarchar(128)
DECLARE @provider nvarchar(128)
DECLARE @datasrc nvarchar(4000)
DECLARE @location nvarchar(4000)
DECLARE @provstr nvarchar(4000)
DECLARE @catalog nvarchar(128)
-- Set parameter values
SET @server = 'XLTEST_SP'
SET @srvproduct = 'Excel'
SET @provider = 'Microsoft.Jet.OLEDB.4.0'
SET @datasrc = 'c:\excel_import.xls'
SET @provstr = 'Excel 8.0'
EXEC @RC = [master].[dbo].[sp_addlinkedserver] @server, @srvproduct, @provider,
@datasrc, @location, @provstr, @catalog

导入:

SELECT * INTO excel_import FROM OPENQUERY(XLTEST_SP,   'SELECT * FROM [sheet1$]')

参考http://alwayswith.javaeye.com/blog/394028
posted @ 2011-03-07 11:09  mrcoolye  阅读(775)  评论(0编辑  收藏  举报