September 23, 2011 at 7:06 am
My batch of sql uses few synonyms pointing to a table on another server. Now when i run this query i see that 97% of the cost is on this remote query , if i copy the database local and run the same query cost is equally spread across. Is this the issue with the linked server or the indexes? I can try to post the exec plan , but is it like execution plan doesnt show up which indexes it is using on a remote server?
September 23, 2011 at 7:19 am
That's one of the limits of plans. Anything done remotely comes back as one black box general step, usually with super high %.
The only way to debug is to run that part of the statement on the remote server. Tune that there. Then assume it's fine when you run it locally.
I say assume but I also check that if it takes 1 sec to run on the remote server that it still takes only 1 sec in the mixed server query.
I never had any super duper critical query in that situation so my research stopped there.
Hopefully Grant or Gail have more to offer on this matter.
September 25, 2011 at 2:34 am
Ninja's_RGR'us (9/23/2011)
That's one of the limits of plans. Anything done remotely comes back as one black box general step, usually with super high %.The only way to debug is to run that part of the statement on the remote server. Tune that there. Then assume it's fine when you run it locally.
I say assume but I also check that if it takes 1 sec to run on the remote server that it still takes only 1 sec in the mixed server query.
I never had any super duper critical query in that situation so my research stopped there.
Hopefully Grant or Gail have more to offer on this matter.
Makes sense. I actually copied all the databases locally on a test box and piece which was showed up as 97% usage in prod...is just now showing less than 4 %.
September 25, 2011 at 5:34 am
For remote queries, to see what they are doing, you must look at those queries on the remote server as well as locally.
"The credit belongs to the man who is actually in the arena, whose face is marred by dust and sweat and blood"
- Theodore Roosevelt
Author of:
SQL Server Execution Plans
SQL Server Query Performance Tuning
September 25, 2011 at 7:38 pm
You can't necessarily believe the cost basis of the things in the Execution Plan, anyway. The "cost" is one of those things known to lie especially if any "Hidden RBAR" comes into play.
--Jeff Moden
Change is inevitable... Change for the better is not.
September 26, 2011 at 8:31 am
Jeff Moden (9/25/2011)
You can't necessarily believe the cost basis of the things in the Execution Plan, anyway. The "cost" is one of those things known to lie especially if any "Hidden RBAR" comes into play.
What is the best way then?
September 26, 2011 at 8:40 am
Trace to see the real total cost.
You can see it by statement & batches. And get the actual execution plan as well.
Viewing 7 posts - 1 through 6 (of 6 total)
You must be logged in to reply to this topic. Login to reply