opendatasource mysql_通过异类查询(OpenDataSource)把外部数据(Excel,TXT)导入到SqlSe

本文介绍了如何在SQLServer中利用OpenDataSource和OLEDB驱动引擎将Excel和TXT格式的数据导入到数据库。通过创建存储过程sp_ReadXLSSource和sp_ReadSource,详细展示了具体的SQL语句和配置步骤,包括环境准备、文件格式要求和执行检查。
摘要由CSDN通过智能技术生成

无论用sqlcmd或者通过C#逻辑处理,或者还是直接在SqlServer里执行操作,个人总结大概不过可归总为这两种方式: 1,SSIS; 2,OLEDB驱动引擎。 SSIS实在也好用,现在这里先不去讨论。其中大多数人用的都是第二种方法,下面,本人也以第二种方法在SqlServer里导

无论用sqlcmd或者通过C#逻辑处理,或者还是直接在SqlServer里执行操作,个人总结大概不过可归总为这两种方式:

1,SSIS;

2,OLEDB驱动引擎。

SSIS实在也好用,现在这里先不去讨论。其中大多数人用的都是第二种方法,下面,本人也以第二种方法在SqlServer里导入excel和txt格式文件的具体实例来说明怎样在项目里灵活通过OLEDB导入数据!

一,必要的环境说明

本实例用sql语句在SqlServer里面完成对数据的导入操作。

在本实例开始之前,可能需要先安装AccessDatabase引擎包

(本人机器64位,安装的是32位的office组件,所以需要另外安装office驱动引擎包(此引擎包作用在于使得office系统文件与office应用程序之间进行数据传输) - 此步骤中需要先卸载32位office组件,否则会提示驱动安装不成功)

本人所用引擎包下载地址如下:

http://www.microsoft.com/zh-cn/download/details.aspx?id=13255

安装完成后,具体配置可以这里配,建议如非必要,默认就好。

f9a526b6c3d2022bb006758698606a32.png

二,代码准备 - 建数据库及存储过程

建数据库这里不多说,建立与导入数据相匹配的数据库而已。

而为了项目拓展及方便使用管理,需要创建存储过程,目的是为了批量导入外部数据。

因为本例以excel和txt分别来做实例说明,所以,需要新建两个存储过程 - "sp_ReadXLSSource"和"sp_ReadSource"。代码分别如下:

存储过程:sp_ReadXLSSource

USE [CUSTOMS]

GO

/****** Object: StoredProcedure [dbo].[sp_ReadXLSSource] Script Date: 11/21/2014 3:01:39 PM ******/

SET ANSI_NULLS ON

GO

SET QUOTED_IDENTIFIER ON

GO

ALTER PROCEDURE [dbo].[sp_ReadXLSSource]

@trgPath varchar(255),

@trgTable varchar(255),

@xlsFile varchar(255),

@xlsSheet varchar(255),

@xlsFields varchar(8000)

AS

declare @mySql varchar(8000)

declare @myIntermediate varchar(8000)

declare @Firstfield varchar(100)

declare @FirstfieldValue varchar(100)

--Lookup lastfield

set @Firstfield = dbo.fnGetFirstField(@xlsFields)

set @FirstfieldValue = RTRIM(LTRIM(SUBSTRING(@Firstfield,2,CHARINDEX(']',@Firstfield,0)-2)))

--PRINT @FirstfieldValue

--Drop table if exists

set @myIntermediate = 'IF EXISTS (SELECT * FROM sys.objects WHERE object_id = OBJECT_ID(N''[dbo].[' + @trgTable + ']'') AND type in (N''U''))'

set @mySql = @myIntermediate + ' DROP TABLE ' + @trgTable

exec(@mySql)

--PRINT @mySql

--Load Table

set @mySql = 'SELECT ' + @xlsFields + ' INTO ' + @trgTable + ' FROM OPENROWSET(''Microsoft.ACE.OLEDB.12.0'',

''Excel 12.0;DATABASE=' + @trgPath + '\' + @xlsFile + ';IMEX=1'', ''Select * from ' + @xlsSheet + ''')'

+ 'WHERE NOT ' + @Firstfield + ' IS NULL'

--PRINT @mySql

exec(@mySql)存储过程:sp_ReadSourceUSE [WOOX_CQM]

GO

/****** Object: StoredProcedure [dbo].[sp_ReadSource] Script Date: 11/21/2014 2:54:33 PM ******/

SET ANSI_NULLS ON

GO

SET QUOTED_IDENTIFIER ON

GO

ALTER PROCEDURE [dbo].[sp_ReadSource]

@trgPath varchar(255),

@trgTable varchar(255),

@trgFields varchar(8000)

AS

declare @mySql varchar(8000)

declare @myIntermediate varchar(8000)

declare @Firstfield varchar(100)

declare @FirstfieldValue varchar(100)

--Lookup lastfield

set @Firstfield = dbo.fnGetFirstField(@trgFields)

set @FirstfieldValue = RTRIM(LTRIM(SUBSTRING(@Firstfield,2,CHARINDEX(']',@Firstfield,0)-2)))

--PRINT @FirstfieldValue

--Drop table if exists

set @myIntermediate = 'IF EXISTS (SELECT * FROM sys.objects WHERE object_id = OBJECT_ID(N''[dbo].[' + @trgTable + ']'') AND type in (N''U''))'

set @mySql = @myIntermediate + ' DROP TABLE ' + @trgTable

exec(@mySql)

--PRINT @mySql

--Load Table

set @mySql = 'SELECT ' + @trgFields + ' INTO ' + @trgTable + ' ' +

'FROM OpenDataSource (''Microsoft.ACE.OLEDB.12.0'',

''Data Source="' + @trgPath + '";Extended properties=Text'')...'

+ @trgTable + '#txt '

+ 'WHERE NOT ' + @Firstfield + ' IS NULL AND ' + @Firstfield + ' <> ' + '''' + @FirstfieldValue + ''''

--PRINT @mySql

exec(@mySql)

三,文件准备,导入源及Schema.ini配置文件

对于excel文件来说,相对txt格式,实在简单很多,关键不过以下这段代码

TRUNCATE TABLE WOOX_INFORMATICA..VBPA;

INSERT INTO WOOX_INFORMATICA..VBPA select * FROM OPENROWSET('Microsoft.ACE.OLEDB.12.0', 'Excel 12.0;Database=C:\InitialData\db_data.xlsx;HDR=YES', 'SELECT * FROM [VBPA$]')

--(适用于office2007及以上版本,2003用Jet - "Microsoft.Jet.OLEDB.4.0")其它需要注意的不过就是保证excel内的数据格式是统一的文本格式,这里只简单给出事例图,不做详细说明。

f6eaf096c1b535b7ca8c8ee7daa481b0.png

对于txt格式文件,本人所用格式如下。

94a7993c0313f9bacd1886e0b78429eb.pngvcr9vt21xMXk1sPOxLz+U2NoZW1hLmluaaOhyOe5+7W8yOuyu7PJuaa78tXfs/a07aOstPO2vMrH1eLSu7K91ui07cHLPGJyPgqjqHBzo7q0y8Xk1sPOxLz+0qq6zbW8yOvUtLfF1NrNrNK7uPbOxLz+vNDPwqOswe3N4qOszsS8/rzQxL/CvNfuusOx8Myrs6S78tXfsPy6rNPQv9UmIzI2Njg0O9auwOC1xKOs1eLQqdfUvLrXotLio6GjqTxicj4KxuTW0FNjaGVtYS5pbmnA77nmt7YmIzI2Njg0O8q9yOfPwqGjPHByZSBjbGFzcz0="brush:sql;">[SAP_TVSTZ.txt]

FORMAT=Delimited(|)

ColNameHeader=True

MaxScanRows=0

CharacterSet=Unicode

TextDelimiter=`

Col1=SKIP1 TEXT

Col2=SKIP2 TEXT

COL3=VSBED TEXT

COL4=LADGR char(100)

COL5=WERKS TEXT

COL6=LGORT TEXT

COL7=VSTEL TEXT

42e4848b3f072d7a08590afc911744f0.png

这里需要标明的是:域值内,第一行表示数据源文件名;第二行至第六行是必要的设置和说明,每个人按需修改;第七行以下必须按照Col从1索引开始递增,右边是显示的列名及格式。具体有兴趣的同学可以自己试着操作下,看下差异。

四,执行及检查

执行代码如下USE WOOX_CQM

EXECUTE sp_ActivateDistributedQueries

----------------------------- SAP Tables -----------------------------

DECLARE @LoadPath varchar(2000)

SET @LoadPath = 'C:\InitialData\SAPdata'

--import Excel--

EXECUTE sp_ReadXLSSource

@LoadPath,

'SAP_TCURF', 'SAP_TCURF.xls', '[Sheet1$]',

'[KURST],[FCURR],[TCURR],[GDATU], [FFACT],[TFACT],[FromDate],[ToDate]'

--import txt--

EXECUTE sp_ReadSource

@LoadPath,

'SAP_TVSTZ',

'[VSBED],[LADGR],[WERKS],[LGORT],[VSTEL]'可用以下代码先行测试导入数据是否有差距,同学们记得更改本人所用的hardcored。select *

FROM OpenDataSource ('Microsoft.ACE.OLEDB.12.0',

'Data Source="C:\InitialData\SAPdata";Extended properties=Text')...SAP_TW06S#txtok,大概代码就是这样,如果有什么不懂或者有不同意见的,可用留言讨论!

f68f2add0b68e4f9810432fce46917b7.png

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值