MSSQL linkedServer和OpenDataSource比较

来源:互联网 发布:幼儿园美工课教案大班 编辑:程序博客网 时间:2024/06/05 02:09

在MSSQL中, 对远程的数据库进行访问有几种方式, 其中 LinkedServer是大家最常使用的方式。

创建好linkedserver之后,对远程数据库实例的访问,就像访问本地的数据库一样, 直接 使用[linkedserver_name].[db_name].[owner].[table_name]来访问。

这样的话,就不用每次都提供远程机器的用户名和密码。


但是linkedserver也有潜在的问题, 就是linked ring的问题。

假设有数据库A 在机器A上, 数据库B在机器B上, 你可以建立从A-》B的linksed Server, 也可以建立从B-》A的LinkedServer。 一般情况下,还好。

但是当你想使用link server 来做delete 动作的时候,就要特别的当心了。  

笔者就曾遇到过, 用link server从A-》B对B进行delete操作的时候,发现 A中的数据不见了, 当时觉得很纳闷。

查log发现 是B有一个对A的linked Server, 笔者要删除的动作引发了从B到A的删除。 这个是一开始没有想到 的。

这种情况在接手比较老的项目中可能存在。 



除了linked Server, 我们还可以使用opendatasource来访问。

OPENDATASOURCE('SQLNCLI','Data Source=machine_host;User ID=name;Password=*******').[db_name].[owner].[table_name]


这两个之间哪一个更好呢?

1)  Linked Server 不需要开advanced Option, 但是OpenDataSource需要启用“Ad Hoc Distributed Queries”。

2) Linked Server只要创建一次, 就可以随意访问, 但是OpenDataSource每次都要提供密码。

3)OpenDataSource的性能比LinkedServer差一点。 LinkedServer适合访问比较频繁的情况下, 而OpenDataSource主要用来进行次数很少的访问。


两者之间更多的区别,请参考 http://msdn.microsoft.com/en-us/library/ms179856.aspx,