2010年1月5日 星期二

RS 2000 中的openquery

有一張報表需求會同時用到sql 2000和informix 的table.
採用linked server的方式,分散式查詢最好要組好完成sql語句,再送到遠端伺服器進行查詢後傳回結果.
之前使用者為了方便,把openquery的語法建成view, 像這樣
create view vTest as
select * from openquery (linkedsvr, 'select * from remoteTable")

想當然耳, 雖然查詢時 select * from vTest where condiditon.... 有指定條件,
但以openquery 來說, 可是會先把remote table所有的資料下傳回sql server後再進行處理的.
造成整個resource都被吃光了.

所以改寫成以sp_executesql的方法組出sql字串送到 remote db去查詢完成後送回結果

declare @sql as nvarchar(4000)
set @sql = N'select * into #tmpTest from openquery (linkedsvr, ''select * from remoteTabl where condition'') ;

select * from #tmpTest inner join tableInSQLServer ......'
exec sp_executesql @sql

這樣就可以利用tmp table, 一次包在同一個transaction與sql server 的table做join查詢了

雖然很不方便 ,但拿sql server當跳板做事總要犧牲一點吧.

沒有留言:

張貼留言

SSAS 作業已因鎖定衝突而取消

SSAS在process 與 mdx query並存應用時,如果mdx 語法含crossjoin或維度member很多時,就容易顯示錯誤【作業已因鎖定衝突而取消。】 當然,SSAS應是process與 query分開時段執行,但因種種先知後知原因,專案就是有需要這樣應用,即使是已...