8

我已经看过所有关于如何在两个不同的 SQL 服务器上查询两个不同的表的参考资料,并且我了解它是如何实现的。但是,该命令似乎不适用于使用##.

如果我在一台服务器上编写连接,并且它引用该服务器上的一个临时表和另一台服务器上的一个临时表,SQL Server 假定因为##命令中的 ,它会自动查看本地服务器的tempdb,而不是远程一。我此时也无法使用OPENROWSET,因为该功能已被禁用,我必须获得批准才能重新打开它。

所以我的问题是有一种方法可以重新配置此命令以识别tempdb要查看的命令吗?

SELECT * 
FROM (##mytemptable1 Demog 
INNER JOIN MyServer.tempdb.dbo.##mytemptable2 PeakInfo ON (Demog.SAMPLE_NO = PeakInfo.SampleNum)  AND  (Demog.JOB_NO = PeakInfo.JobNum) )
ORDER BY PeakInfo.JobNum, PeakInfo.SampleNum,   PeakInfo.Replicate ,PeakInfo.Reinjection ,PeakInfo.PeakNameCustSort
4

2 回答 2

19

试试这个从链接服务器查询全局临时表

SELECT * FROM OPENQUERY(linkedServerName, 'SELECT * FROM ##temp')
于 2014-08-20T16:21:24.413 回答
1

MSDN http://msdn.microsoft.com/en-us/library/ms186986(v=sql.105).aspx说全局临时表仅在 SQL Server 的特定实例上可见:

全局临时表在创建后对任何用户和任何连接都是可见的,并在引用该表的所有用户与 SQL Server 实例断开连接时被删除。

此外,对远程全局临时表尝试的任何操作都会导致明确的错误消息:

SELECT * FROM LinkedServerName.TempDB.dbo.##GLOBTABLE

Database name 'TempDB' ignored, referencing object in tempdb.

看起来答案是否定的,没有(简单的)方法。

于 2012-12-27T17:37:20.623 回答