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

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

我无法将Access数据库转换为新版本。 它正在被第三方应用程序使用; 所以不得以任何方式修改它。

我已经尝试使用Jet 4.0 OLE DB提供程序和ODBC OLE DB提供程序。 第三方应用程序创build一个系统DSN(具有适当的数据库密码),但我没有任何运气使用任何一种方法。

如果我使用的是标准连接string,我认为它看起来像这样:

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

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

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

谢谢!

方法#1 – 使用Jet 4.0提供程序当我尝试运行这些语句来创build链接服务器时:

 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 

testing连接时出现此错误:

 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) 

经过几个小时的苦苦挣扎之后,我终于找不到一个,而是两个解决scheme! 我正在使用SQL Server 2008和Access 2000,但我想解决scheme是一样的。

解决scheme1:使用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 

解决scheme2:使用链接服务器

正如你已经说过的,链接的服务器似乎不工作。 然而,有一个小问题让一切顺利。 您需要在提供程序string中指定数据库密码,如;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 

您似乎不区分数据库密码(Jet 3.0中首先介绍的,A95中Jet的版本)和Jet用户级安全用户名/密码。 你的例子都是后者,但是在你的问题中你提到了数据库密码。 只有OLEDB支持(ODBC不),所以你需要检查http://www.connectionstrings.com/access OLEDB连接string与数据库密码。