MSSQL linkedServer和OpenDataSource比较

本文对比了MSSQL中通过LinkedServer和OpenDataSource两种方式访问远程数据库的方法,讨论了它们的优缺点及适用场景。

在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,  




### 使用 `OPENDATASOURCE` 函数在 SQL Server 2000 中访问外部数据源 在 SQL Server 2000 中,`OPENDATASOURCE` 是一种动态连接远程服务器的方法。此功能允许临时链接到 OLE DB 数据提供程序而无需创建永久性的链接服务器对象。 #### 访问 Excel 文件的数据 为了从 Excel 文件读取数据并将其作为表返回给 SQL 查询,可以使用如下语法: ```sql SELECT * FROM OPENDATASOURCE( 'Microsoft.Jet.OLEDB.4.0', 'Data Source=C:\path\to\yourfile.xls;Extended Properties="Excel 8.0"' ). [...]SheetName$ ``` 这里需要注意的是,在指定扩展属性时应确保版本号匹配所使用的 Excel 版本[^2]。 对于较新的 Excel 文件(如 .xlsx),则应该调整驱动器名称为 `'Microsoft.ACE.OLEDB.12.0'` 并相应更改其他参数设置以适应新格式的要求[^3]。 #### 插入 Excel 数据至 SQL 表格 当需要将来自 Excel 的记录插入现有的数据库表内时,可以通过组合上述查询方式来实现这一点。假设目标是要把名为 "test.xlsx" 的电子表格里特定工作表的内容复制到本地的一个叫做 `test.dbo.test` 的表结构中,则命令可能看起来像这样: ```sql INSERT INTO test.dbo.test (ColumnA, ColumnB, ...) SELECT * FROM OPENDATASOURCE ( 'Microsoft.Jet.OLEDB.4.0', 'Data Source=C:\Data\DDfiles\test.xlsx;' + 'Extended Properties="Excel 8.0;HDR=YES;"' ).[...SheetName$] WHERE ... ``` 这里的 `[...]SheetName$` 部分应当替换为你实际要操作的工作表的名字;如果不确定具体名字的话,默认情况下会是类似于 `Sheet1$`, `Sheet2$` 这样的形式[^4]。 请注意,由于安全性考虑以及性能方面的原因,在生产环境中执行此类跨平台的操作之前最好先进行全面测试,并且只授予必要的权限给涉及的对象服务账户。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值