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

转载于:https://www.cnblogs.com/yfdong22/archive/2011/03/07/1973379.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值