关于ACCESS数据转为SQL SERVER数据表

本文档介绍了如何配置SQL SERVER以启用Ad Hoc Distributed Queries,并通过T-SQL语句将ACCESS数据导入到SQL SERVER中,包括查询ACCESS数据、创建新表以及反向将SQL SERVER数据写入ACCESS的方法。请注意,未启用Ad Hoc Distributed Queries会导致操作失败。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.关于配置

--启用Ad Hoc Distributed Queries
exec sp_configure 'show advanced options',1
reconfigure
exec sp_configure 'Ad Hoc Distributed Queries',1
reconfigure
--使用完成后,关闭Ad Hoc Distributed Queries:
exec sp_configure 'Ad Hoc Distributed Queries',0
reconfigure
exec sp_configure 'show advanced options',0
reconfigure

 

2.T-SQL(其中AAAA为表名)

--查询ACCESS表里的数据

SELECT  *  FROM OPENDATASOURCE ('Microsoft.ace.OLEDB.12.0',
'Data Source="F:/CC.accdb";User ID=Admin;Password=;') ...AAAA

 --插入到一个新表中,此表不存在

SELECT  * INTO NEWTABLE  FROM OPENDATASOURCE ('Microsoft.ace.OLEDB.12.0',
'Data Source="F:/CC.accdb";User ID=Admin;Password=;') ...AAAA

--将SQL SERVER表里的数据插入到ACCESS

--

insert into OpenDataSource( 'Microsoft.ace.OLEDB.12.0','Data Source="F:/CC.accdb";User ID=Admin;Password=')...AAAA(列A,列B,列C)
select 列1,列2,列3  from  NEWTABLE

 

3.备注

1)如果没有启用Ad Hoc Distributed Queries则在运行T-SQL时会提示“SQL Server 阻止了对组件 'Ad Hoc Distributed Queries' 的 STATEMENT'OpenRowset/OpenDatasource' 的访问,因为此组件已作为此服务器安全配置的一部分而被关闭。系统管理员可以通过使用 sp_configure 启用 'Ad Hoc Distributed Queries'。有关启用 'Ad Hoc Distributed Queries' 的详细信息,请参阅 SQL Server 联机丛书中的 "外围应用配置器"。 ”
2)'Microsoft.ace.OLEDB.12.0'为ACCESS 2007的数据引擎

'Microsoft.JET.OLEDB.12.0'为ACCESS 2003的数据引擎

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值