AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 114384
In Process
Brad Knowles
Brad Knowles
Asked: 2010-02-19 12:05:56 +0800 CST2010-02-19 12:05:56 +0800 CST 2010-02-19 12:05:56 +0800 CST

如何在 SQL Server 2005 中为受密码保护的 Access 95 数据库创建链接服务器?

  • 772

我需要使用 SQL Server Management Studio 2005 创建一个连接到 Access 95 数据库的链接服务器,该数据库恰好在数据库级别受到密码保护。尚未实施用户级安全性。

我无法将 Access 数据库转换为较新的版本。它正在被第 3 方应用程序使用;因此,不允许以任何方式对其进行修改。

我试过使用 Jet 4.0 OLE DB Provider 和 ODBC OLE DB Provider。第 3 方应用程序创建了一个系统 DSN(使用正确的数据库密码),但我在使用这两种方法时都没有运气。

如果我使用标准连接字符串,我认为它看起来像这样:

Provider=Microsoft.Jet.OLEDB.4.0;Data Source='C:\Test.mdb';Jet OLEDB:Database Password=####;

我相当确定我需要以某种方式合并Jet OLEDB:Database Password到链接服务器设置中,但还没有弄清楚如何。

我已经发布了我正在使用的脚本以及下面的相关错误消息。任何帮助是极大的赞赏。如果需要,我会提供更多详细信息,请问。

谢谢!

方法 #1 - 使用 Jet 4.0 Provider 当我尝试运行这些语句来创建链接服务器时:

sp_dropserver 'Test', 'droplogins';
EXEC sp_addlinkedserver @server = N'Test', @provider = N'Microsoft.Jet.OLEDB.4.0',
    @srvproduct = N'Access DB', @datasrc = N'C:\Test.mdb'
GO

EXEC sp_addlinkedsrvlogin @rmtsrvname=N'Test', @useself=N'False',@locallogin=NULL,
    @rmtuser=N'Admin', @rmtpassword='####'
GO

测试连接时出现此错误:

TITLE: Microsoft SQL Server Management Studio
------------------------------

"The test connection to the linked server failed."

------------------------------
ADDITIONAL INFORMATION:

An exception occurred while executing a Transact-SQL statement or batch. (Microsoft.SqlServer.ConnectionInfo)

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

The OLE DB provider "Microsoft.Jet.OLEDB.4.0" for linked server "Test" reported an error. Authentication failed.
Cannot initialize the data source object of OLE DB provider "Microsoft.Jet.OLEDB.4.0" for linked server "Test".
OLE DB provider "Microsoft.Jet.OLEDB.4.0" for linked server "Test" returned message "Cannot start your application. The workgroup information file is missing or opened exclusively by another user.". (Microsoft SQL Server, Error: 7399)

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

方法 #2 - 使用 ODBC 提供程序...

sp_dropserver 'Test', 'droplogins';
EXEC sp_addlinkedserver @server = N'Test', @provider = N'MSDASQL', 
    @srvproduct = N'ODBC', @datasrc = N'Test:DSN'
GO

EXEC sp_addlinkedsrvlogin @rmtsrvname=N'Test', @useself=N'False',@locallogin=NULL,
    @rmtuser=N'Admin', @rmtpassword='####'
GO

我收到此错误:

TITLE: Microsoft SQL Server Management Studio
------------------------------

"The test connection to the linked server failed."

------------------------------
ADDITIONAL INFORMATION:

An exception occurred while executing a Transact-SQL statement or batch. (Microsoft.SqlServer.ConnectionInfo)

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

Cannot initialize the data source object of OLE DB provider "MSDASQL" for linked server "Test".
OLE DB provider "MSDASQL" for linked server "Test" returned message "[Microsoft][ODBC Driver Manager] Driver's SQLSetConnectAttr failed".
OLE DB provider "MSDASQL" for linked server "Test" returned message "[Microsoft][ODBC Driver Manager] Driver's SQLSetConnectAttr failed".
OLE DB provider "MSDASQL" for linked server "Test" returned message "[Microsoft][ODBC Microsoft Access Driver] Cannot open database '(unknown)'.  It may not be a database that your application recognizes, or the file may be corrupt.". (Microsoft SQL Server, Error: 7303)
sql-server-2005 microsoft-access linked-server
  • 2 2 个回答
  • 7925 Views

2 个回答

  • Voted
  1. MarioVW
    2011-10-01T09:06:17+08:002011-10-01T09:06:17+08:00

    经过几个小时的努力解决这个问题,我终于找到了两个解决方案,而不是一个!我使用的是 SQL Server 2008 和 Access 2000,但我想解决方案是一样的。

    解决方案 1:使用 OPENDATASOURCE

    当您不经常访问链接服务器上的数据时,请使用此方法:

    select * from 
    OPENDATASOURCE('Microsoft.JET.OLEDB.4.0', 'Data Source=C:\MyAccessDB.mdb;User ID=Admin;Password=;Jet OLEDB:Database Password=MyDBPassword;')...MyTable
    

    为此,您还需要打开该Ad Hoc Distributed Queries选项:

    exec sp_configure 'show advanced options', 1;
    RECONFIGURE;
    exec sp_configure 'Ad Hoc Distributed Queries', 1;
    RECONFIGURE;
    GO
    

    解决方案 2:使用链接服务器

    正如您已经说过的,链接服务器似乎不起作用。但是,有一个小问题可以让一切顺利进行。您需要在提供程序字符串中指定数据库密码,例如;PWD=password.

    exec sp_addlinkedserver 
        @server = 'TestLinkServer', 
        @provider = 'Microsoft.Jet.OLEDB.4.0', 
        @srvproduct = 'Access',
        @datasrc = 'C:\MyAccessDB.mdb', 
        @provstr = ';PWD=MyDBPassword'
    
    exec sp_addlinkedsrvlogin 
        @rmtsrvname = 'TestLinkServer',
        @useself = 'FALSE',
        @locallogin = null, 
        @rmtuser = 'Admin', 
        @rmtpassword = null
    

    去

    现在您可以将 Access 数据库作为链接服务器进行查询:

    select * from TestLinkServer...MyTable
    
    • 3
  2. David W. Fenton
    2010-08-31T11:46:41+08:002010-08-31T11:46:41+08:00

    您似乎没有区分数据库密码(在 Jet 3.0 中首次引入,A95 中的 Jet 版本)和 Jet 用户级安全用户名/密码。您的示例都是后者,但是您在问题中提到了数据库密码。只有 OLEDB 支持(ODBC 不支持),因此您需要检查http://www.connectionstrings.com/access以获取 OLEDB 连接字符串和数据库密码。

    • 0

相关问题

  • 为什么当我尝试删除数据库时 SQL Server 2005 挂起?

  • SQL 洗衣清单

  • 如何提高 SQL Server 镜像性能

  • 聚集索引与非聚集索引?

  • 安全地授予对 SQL 2005 复制监视器的访问权限以创建快照

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    从 IP 地址解析主机名

    • 8 个回答
  • Marko Smith

    如何按大小对 du -h 输出进行排序

    • 30 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    MikeN 在 Nginx 中,如何在维护子域的同时将所有 http 请求重写为 https? 2009-09-22 06:04:43 +0800 CST
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    0x89 bash中的双方括号和单方括号有什么区别? 2009-08-10 13:11:51 +0800 CST
  • Martin Hope
    Kyle Brandt IPv4 子网如何工作? 2009-08-05 06:05:31 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve