使用无效的架构或目录链接服务器的 OLE DB 提供程序"SQLNCLI"为""
2011-12-21 10:59
711 查看
我们必须从 SQL Server 2005 实例链接服务器以 SQL Server 2000 实例。链接的服务器工作正常。但是如果我们尝试查询链接服务器通过由四部分组成的名称然后将它失败与下面的错误消息
为了解决此问题,请检查是否 SQLNCLI oledb 提供程序"零水平只有"属性设置为 0。如果它
7399 都是 1 (或对),将发生错误。请确保其未选中状态。
要将"零水平只有"属性的设置,请转到
SQL 管理工作室->"服务器对象"->"链接的服务器"->"供应商"
右键单击"SQLNCLI"和转到属性并取消选中"零水平只有"属性
单击"确定",重新启动 SQL Server 服务。
您还可以更改此设置,通过注册表
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Microsoft SQL Server\MSSQL.1\Providers\SQLNCLI
LevelZeroOnly
如果我们将它设置为 1 然后允许仅 0 级 OLE DB 提供程序。如果是 0 (默认值),则允许 OLE DB 提供程序的所有级别。所以,该值指定是否支持所有 OLE DB 提供程序,或只是那些符合级别 0 OLE DB 接口。
其他解决方法是使用 OPENQuery 而不是 Four-Part 查询
SELECT *
FROM LinkServer.Northwind.dbo.Shippers
Error Message
Msg 7399, Level 16, State 1, Line 1
The OLE DB provider "SQLNCLI" for linked server "<Linked Server Name>" reported an error. The provider did not give any information about the error.
Msg 7312, Level 16, State 1, Line 1
Invalid use of schema or catalog for OLE DB provider "SQLNCLI" for linked server "<Linked Server Name>". A four-part name was supplied, but the provider does not expose the necessary interfaces to use a catalog or schema..
为了解决此问题,请检查是否 SQLNCLI oledb 提供程序"零水平只有"属性设置为 0。如果它
7399 都是 1 (或对),将发生错误。请确保其未选中状态。
要将"零水平只有"属性的设置,请转到
SQL 管理工作室->"服务器对象"->"链接的服务器"->"供应商"
右键单击"SQLNCLI"和转到属性并取消选中"零水平只有"属性
单击"确定",重新启动 SQL Server 服务。
您还可以更改此设置,通过注册表
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Microsoft SQL Server\MSSQL.1\Providers\SQLNCLI
LevelZeroOnly
如果我们将它设置为 1 然后允许仅 0 级 OLE DB 提供程序。如果是 0 (默认值),则允许 OLE DB 提供程序的所有级别。所以,该值指定是否支持所有 OLE DB 提供程序,或只是那些符合级别 0 OLE DB 接口。
其他解决方法是使用 OPENQuery 而不是 Four-Part 查询
相关文章推荐
- 链接服务器的 OLE DB 访问接口 "SQLNCLI" 无法启动分布式事务 OLE DB 提供程序 'SQLOLEDB' 无法启动分布式事务
- SQL Server 2008 R2运行分布式的查询时的错误消息:"链接服务器 < 链接服务器 > 的 OLE DB 提供程序 SQLNCLI 返回消息没有事务处于活动状态
- 无法执行该操作,因为链接服务器 "xxxxx" 的 OLE DB 访问接口 "SQLNCLI" 无法启动分布式事务 .
- 链接服务器 "(null)" 的 OLE DB 访问接口 "Microsoft.Ace.OleDb.12.0" 报错。提供程序未给出有关错误的任何信息。
- 因为链接服务器 "IP" 的 OLE DB 访问接口 "SQLNCLI" 无法启动分布式事务
- 无法启动链接服务器 "........" 的 OLE DB 访问接口 "SQLNCLI10" 的嵌套事务。由于 XACT_ABORT 选项已设置为 OFF,因此必须使用嵌套事务。
- 链接服务器 "(null)" 的 OLE DB 访问接口 "Microsoft.Ace.OleDb.12.0" 报错。提供程序未给出有关错误的任何信息。
- 无法启动链接服务器 "XXXXXX" 的 OLE DB 访问接口 "MSDASQL" 的嵌套事务。由于 XACT_ABORT 选项已设置为 OFF,因此必须使用嵌套事务。
- 无法执行该操作,因为链接服务器 "xxxxx" 的 OLE DB 访问接口 "SQLNCLI" 无法启动分布式事务
- 因为链接服务器 "XXXX" 的 OLE DB 访问接口 "SQLNCLI10" 无法启动分布式事务
- 链接服务器 OLE DB 访问接口 "SQLNCLI10" 返回了消息 "该伙伴事务管理器已经禁止了它对远程/网络事务的支持。"
- SQL Server 解决 "无法执行该操作,因为链接服务器 的 OLE DB 访问接口 "SQLNCLI10" 无法启动分布式事务"
- Microsoft OLE DB Provider for SQL Server (0x80040E14) 已拒绝对 OLE DB 提供程序 'Microsoft.Jet.OLEDB.4.0' 的特殊访问。必须通过链接服务器来访问此提供程序。
- 没有活动事务 链接服务器的 OLE DB 访问接口 "SQLNCLI" 无法启动分布式事务
- 已拒绝对 OLE DB 提供程序 'Microsoft.Jet.OLEDB.4.0' 的特殊访问。必须通过链接服务器来访问此提供程序。
- 因为链接服务器 "SQLEHR" 的 OLE DB 访问接口 "SQLNCLI10" 无法启动分布式事务
- 在linux上使用"scp"命令拷贝一个目录到另一台服务器的时候报"not a regular file"错误的解决办法
- 无法执行该操作,因为链接服务器 "xxxxx" 的 OLE DB 访问接口 "SQLNCLI" 无法启动分布式事务
- 无法创建链接服务器 "ORCL" 的 OLE DB 访问接口 "OraOLEDB.Oracle" 的实例 (错误:7302)
- 无法创建链接服务器 "xxx" 的 OLE DB 访问接口 "OraOLEDB.Oracle" 的实例。 (Microsoft SQL Server,错误: 7302)