CSDN朋友问题回复:

有个ACCESS数据库文件在本机,机器上的OFFICE套件已经卸载,ACCESS没有用户名和密码,如何用MSSQLServer来查询和修改其文件内容?

比如ACCESS物理文件是存放在D盘根目录下的home.mdb,其中包含表'帐户'

一ACCESS数据源查询

方式一:链接服务器

--1 新建链接服务器

EXEC sp_addlinkedserver 'clA',  --名称自己起

'ACCESS',   --数据源产品为access

'Microsoft.Jet.OLEDB.4.0',    --数据源OLEDB

'D:/home.mdb' --access数据文件物理路径

--命令已成功完成。

--2.1 利用OPENQUERY函数查询ACCESS数据库

SELECT top 3 *

FROM OPENQUERY(clA, 'SELECT * FROM 帐户')

Go

--result:

AccountID   AccountNumber                                     AccountName                                        AccountTypeID

----------- -------------------------------------------------- -------------------------------------------------- -------------

1           1001                                               房租费                                               1

2           1002                                               交通费                                               1

3           1003                                               电费                                                1

(3 行受影响)

--2.2 直接查询

select * from clA...帐户

--result:

--结果与.1查询结果一致。

方式二:使用OLE DB 连接并访问远程数据的一次性的临时方法

--更改数据库高级配置选项

/*

sp_configure 'show advanced options',1

reconfigure

sp_configure 'Ad Hoc Distributed Queries',1

reconfigure

*/

--查询ACCESS数据库,table为帐户.

SELECT top 3 *

FROM OPENROWSET('Microsoft.Jet.OLEDB.4.0',

'D:/home.mdb';'admin';'',帐户)

GO

--result:

--结果与.1查询结果一致。

方式三:使用OPENDATASOURCE 连接并访问远程数据的一次性的临时方法

select top 3 *

from OPENDATASOURCE ( 'Microsoft.Jet.OLEDB.4.0'

,'Data Source="D:/home.mdb";User ID=Admin;Password=;')...帐户

--result:

--结果与.1查询结果一致。

总结一:对于ACCESS本地数据源的读取,可以用以上三种方式的任意一种。当mdb存在用户名和密码时,

方式一需要添加远程链接登录名,比如执行如下脚本exec sp_addlinkedsrvlogin 'clA','false',NULL,'用户名','用户密码';

方式二和方式三则分别在'admin';''和User ID=Admin;Password=中输入相应的密码,这里默认用户是admin。

二ACCESS数据源修改

/*

对于数据源的i/u/d类型操作,建议使用远程链接服务器的方式进行(即.1的方式)。

*/

--举例如下:

update clA...帐户set AccountNumber=10010 where AccountNumber=1001 and AccountID = 1

--result:

(1 行受影响)

三发散知识点:

Q:为何对于非MSSQL数据源的i/u/d操作,通常都建议在远程链接服务器方式下进行呢?

A:远程链接服务器是指通过sp_addlinkedserver搭建数据源链接进行访问的一种方式,通常用于长期频繁的数据源的s/i/u/d操作,

相当于直接进行表操作。对于OPENROWSET和OPENDATASOURCE方式通常是进行一次性的应用操作,除了安全性等原因,它们无法进行

安全管理以及查询目录信息的功能。

Q:如果ACCESS不在本机,还可以用上述方式查询吗?

A:变化一下思路,将ACCESS在异地的文件转换为本机。比如home.mdb文件是在.168.1.1机器上,则我们可以使用

//192.168.1.1//共享文件夹/home.mdb形式,当然前提是设置了共享文件夹;另外还可以尝试打开默认共享,比如

//192.168.1.1/D$/home.mdb。当然任何想法和思路都要以适合应用为前提,简单便捷安全为前提。这里仅提供思路,

不表示该方式一定可以实现,因为涉及面不仅仅是数据库方面,还涉及到网络共享等。

在MSSQL中对ACCESS文件操作方式汇总的更多相关文章

  1. C#中实现excel文件批量导入access数据表中

    一 .界面简单设计如下: 二 .代码如下: using System; using System.Collections.Generic; using System.ComponentModel; u ...

  2. [置顶] LOAD语句:利用MSSQL中的xp_cmdshell功能,将指定文件夹下的指定文件,生成mysql的LOAD语句

    LOAD语句:利用MSSQL中的xp_cmdshell功能,将指定文件夹下的指定文件,生成mysql的LOAD语句 declare @sql varchar(4000), @dirpath varch ...

  3. 第9.12节 Python中其他文件操作方式

    一. 引言 本章老猿主要介绍了Python 内置io模块的文件操作相关功能,其实除了内置io模块可以进行文件操作外,Python的不同模块还提供了多种文件操作方式,下面简单将这些模块和方法介绍一下. ...

  4. Microsoft.ACE.OLEDB.12.0 及其在 MSSQL中的使用

    1.Microsoft.ACE.OLEDB.12.0 简介 就是一个数据访问接口,用于在office文件和非office应用程序间传输数据.例如 Microsoft Office Access 201 ...

  5. 【初码干货】使用阿里云对Web开发中的资源文件进行CDN加速的深入研究和实践

    提示:阅读本文需提前了解的相关知识 1.阿里云(https://www.aliyun.com) 2.阿里云CDN(https://www.aliyun.com/product/cdn) 3.阿里云OS ...

  6. mac下查看.mobileprovision文件及钥匙串中证书.cer文件

    mac下查看.mobileprovision文件及钥匙串中证书.cer文件 一. mobileprovision文件查看 xxx.mobileprovision是ios开发中的设备描述文件,里面有证书 ...

  7. C++读取文件夹中所有的文件或者是特定后缀的文件

    由于经常有读取一个文件夹中的很多随机编号的文件,很多时候需要读取某些特定格式的所有文件. 下面的代码可以读取指定文件家中的所有文件和文件夹中格式为jpg的文件 参考: http://www.2cto. ...

  8. 微软BI 之SSIS 系列 - 在 SSIS 中导入 ACCESS 数据库中的数据

    开篇介绍 来自 天善学院 一个学员的问题,如何在 SSIS 中导入 ACCESS 数据表中的数据. 在 SSIS 中导入 ACCESS 数据库数据 ACCESS 实际上是一个轻量级的桌面数据库,直接使 ...

  9. Linux中如何查看文件的最初创建时间

    查看 一个文件的 最初创建时间: Linux中如何查看文件的最初创建时间  linux     目前Linux没有直接查看创建文件的命令,你只能通过文件是否被修改过来进行判断. //查看代码stat  ...

随机推荐

  1. [转] Android开发者必备的42个链接

    下面收集了42个帮助大家学习Android的内容链接,部分内容是面向初学者的,帮助大家从头开始学习Android开发,其他则面向较高级的开发者.希望推荐的这些内容对你有帮助. 官方网站 1.谷歌And ...

  2. C# 跨线程访问或者设置UI线程控件的方法

    一.背景 在C#中,由于使用线程和调用UI的线程属于两个不同的线程,如果在线程中直接设置UI元素的属性,此时就会出现跨线程错误. 二.问题解决方法 使用控件自带的Invoke或者BeginInvoke ...

  3. Entity Framework CodeFirst尝试

    前言 Code First模式我们称之为“代码优先”模式,是从EF4.1开始新建加入的功能.使用Code First模式进行EF开发时开发人员只需要编写对应的数据类(其实就是领域模型的实现过程),然后 ...

  4. C语言内存对齐详解(1)

    一.什么是字节对齐,为什么要对齐? 现代计算机中内存空间都是按照byte划分的,从理论上讲似乎对任何类型的变量的访问可以从任何地址开始,但实际情况是在访问特定类型变量的时候经常在特定的内存地址访问,这 ...

  5. 百度图片爬虫-python版

               self.browser=imitate_browser.BrowserBase()            self.chance=0            self.chanc ...

  6. Windows Server 2012 GUI与Core的切换

    Server Core是在Windows Server 2008 系统上开始引入的极小的服务器安装选项,server core 的作用就是为特定的服务提供一个可执行的功能有限的低维护服务器环境,为我们 ...

  7. 【Django】Django 文件下载最佳实践

    代码: from django.http import StreamingHttpResponse def big_file_download(request): # do something... ...

  8. sharepoint部件webparth关闭找回的方法

  9. 【leetcode】Binary Search Tree Iterator

    Binary Search Tree Iterator Implement an iterator over a binary search tree (BST). Your iterator wil ...

  10. maven3 junit4 spring3 jdk8 :junit一直报错,害的我几个星期都是这个错,你妹的!

    [org.springframework.test.context.junit4.SpringJUnit4ClassRunner]SpringJUnit4ClassRunner constructor ...