Solved

slow running query when update stats hasn't run

Posted on 2011-02-11
11
272 Views
Last Modified: 2012-05-11
     Hi, I have a stor proc that takes normally 2 mins to run, it's loading data into a Type 2 dimension so its doing compares.  The data is about half a million rows a day.  It seems to take 2 mins to run after I have run update stats.  When I haven't ran update stats for the day, it takes 3 hours to run.  This stor proc is part of an etl process, so I don't want to put the update stats in the middle of the package, but I do need it to take its normal time to run (2 min) .  Any suggestions how I can get this to work effciently?
--------------------------------------------------------------------------------
0
Comment
Question by:elucero
  • 4
  • 3
  • 2
  • +2
11 Comments
 
LVL 13

Expert Comment

by:dwkor
ID: 34874981
Compare the plans in both cases and try to tune query with the hints and/or plan guide.
0
 
LVL 15

Expert Comment

by:MohammedU
ID: 34876204
Is Auto Update Stats is on/enabled? If not enable it and see if it improves.

You can run the updatestats as different step before etl runs...
0
 
LVL 25

Expert Comment

by:TempDBA
ID: 34878423
Elucero,
      Did you try for auto update option as Mohammed suggested? Try it out. This must help solve your problem.
0
Comprehensive Backup Solutions for Microsoft

Acronis protects the complete Microsoft technology stack: Windows Server, Windows PC, laptop and Surface data; Microsoft business applications; Microsoft Hyper-V; Azure VMs; Microsoft Windows Server 2016; Microsoft Exchange 2016 and SQL Server 2016.

 

Author Comment

by:elucero
ID: 34880194
Its already turned on.  I can see its really slow when I'm doing an insert into the tbl that has a lot of data, we load about half a million rows a day.  This tbl also has an index on it which is why I'm having this issue.  I'm going to drop the index on the tbl and load it.  Then I'm going to make a working tbl with the index on it and load the daily data into that so I can push it to the mart.  Which would be faster for the working tbl, loading the data with the index already there or dropping and recreating the index when loading?  
0
 

Author Comment

by:elucero
ID: 34880202
Isn't there a way I can run a partial updates stats?  Can I run it on just one tbl?
0
 
LVL 75

Accepted Solution

by:
Anthony Perkins earned 500 total points
ID: 34880284
>>Can I run it on just one tbl?<<
Of course. You can do it this way:
UPDATE STATISTICS YourTableNameGoesHere
0
 
LVL 25

Expert Comment

by:TempDBA
ID: 34894310
And about index thing, if there are lots of inserts happening daily, you can setup a reorganize\rebuild index job to be run daily during off hours.
0
 

Author Comment

by:elucero
ID: 34897387
I got it to work, I took the index off the main tbl the data is inserted into daily (so of course it loads fast again).  I then made a working tbl with the index and loaded just the day data into it to load the dim.  Before I load the working tbl I truncate it and run an update stats against it.  I got the process down to 30 secs.  What is more efficient, running an update stats against the tbl or rebuilding the index?  And why do I need to do either or?  Why does this happen?
0
 
LVL 75

Expert Comment

by:Anthony Perkins
ID: 34903322
It sounds like the query is not getting the appropriate plan.  But without knowing any more details
I can only guess.
0
 

Author Comment

by:elucero
ID: 35002967
what do you mean by appropriate plan?
0
 
LVL 75

Expert Comment

by:Anthony Perkins
ID: 35038804
>>what do you mean by appropriate plan? <<
The SQL plan that the QO uses in order to optimize the query.
0

Featured Post

Best Practices: Disaster Recovery Testing

Besides backup, any IT division should have a disaster recovery plan. You will find a few tips below relating to the development of such a plan and to what issues one should pay special attention in the course of backup planning.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Written by Valentino Vranken. Introduction: The first step of creating a SQL Server Reporting Services (SSRS) report involves setting up a connection to the data source and programming a dataset to retrieve data from that data source.  The data…
Ever needed a SQL 2008 Database replicated/mirrored/log shipped on another server but you can't take the downtime inflicted by initial snapshot or disconnect while T-logs are restored or mirror applied? You can use SQL Server Initialize from Backup…
This video shows how to quickly and easily add an email signature for all users on Exchange 2016. The resulting signature is applied on a server level by Exchange Online. The email signature template has been downloaded from: www.mail-signatures…
Nobody understands Phishing better than an anti-spam company. That’s why we are providing Phishing Awareness Training to our customers. According to a report by Verizon, only 3% of targeted users report malicious emails to management. With compan…

803 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question