Performance regression after SQL Server upgrade

  • HI All,

    I am currently in a situation whereby i have migrated 2 databases from SQL Server 2008 to SQL Server 2016 on an AZURE VM.

    Originally i had upgraded the db's to be compatible with 2016 but performance of a single job regressed so much that i restored the databases again to the original compatibility mode 100.
    When the job was on the old server it rab in less than 5 minutes. when i moved the databases to 2016 comp mode the job took over 1 hour.

    after i restored the database on the 2016 server to comp mode 100 the job takes 30 mins.

    i put the hour long duration down to new features in 2016 such as cardinality enumerator however i cannot figure out why the job is now taking 6 times longer even when in its original comp mode.
    has anyone encountered this issue before and what have they done to resolve? any information would be greatly appreciated.

    Regards,

    Niall

  • niall5098 - Tuesday, July 4, 2017 6:59 AM

    HI All,

    I am currently in a situation whereby i have migrated 2 databases from SQL Server 2008 to SQL Server 2016 on an AZURE VM.

    Originally i had upgraded the db's to be compatible with 2016 but performance of a single job regressed so much that i restored the databases again to the original compatibility mode 100.
    When the job was on the old server it rab in less than 5 minutes. when i moved the databases to 2016 comp mode the job took over 1 hour.

    after i restored the database on the 2016 server to comp mode 100 the job takes 30 mins.

    i put the hour long duration down to new features in 2016 such as cardinality enumerator however i cannot figure out why the job is now taking 6 times longer even when in its original comp mode.
    has anyone encountered this issue before and what have they done to resolve? any information would be greatly appreciated.

    Regards,

    Niall

    Are all of the other migrated jobs running faster, slower or roughly at the same speed as before?
    What does this particular job do?

    The absence of evidence is not evidence of absence.
    Martin Rees

    You can lead a horse to water, but a pencil must be lead.
    Stan Laurel

  • Thanks for responding.

    all other jobs perform the same if not slightly better.

    this particular calls a stored procedure that basically does a massive select into from a view.

    I've had a look at the SPROC syntax and can't see any reference to deprecated datatypes etc

  • niall5098 - Tuesday, July 4, 2017 8:11 AM

    Thanks for responding.

    all other jobs perform the same if not slightly better.

    this particular calls a stored procedure that basically does a massive select into from a view.

    I've had a look at the SPROC syntax and can't see any reference to deprecated datatypes etc

    Have you had a go at getting an actual execution plan for the view & checking for optimisations?
    Have you rebuilt stats?

    The absence of evidence is not evidence of absence.
    Martin Rees

    You can lead a horse to water, but a pencil must be lead.
    Stan Laurel

  • Phil Parkin - Tuesday, July 4, 2017 8:21 AM

    niall5098 - Tuesday, July 4, 2017 8:11 AM

    Thanks for responding.

    all other jobs perform the same if not slightly better.

    this particular calls a stored procedure that basically does a massive select into from a view.

    I've had a look at the SPROC syntax and can't see any reference to deprecated datatypes etc

    Have you had a go at getting an actual execution plan for the view & checking for optimisations?
    Have you rebuilt stats?

    HI,

    I did rebuild indexes and updated stats.
    now, i don't have access to the previous environment to view the previous execution plan.
    i have looked at the query store and forced recommended plans but to no avail.

  • If you are happy to post the plan here as a .sqlplan attachment, someone here may be able to help you (but bear in mind the date ... not many US nationals online today).

    The absence of evidence is not evidence of absence.
    Martin Rees

    You can lead a horse to water, but a pencil must be lead.
    Stan Laurel

  • Even without all the optimizer changes and effects from the new CE in play (once you're on compatibility level 100), there are a lot of ways a particular query might execute differently on a new instance on a new machine.

    What were the specs (CPU, storage, RAM, etc.) of the old server, and what Azure VM size are you using for the new one, with what kind of storage? 

    Without being able to compare anything at the SQL Server layer (wait stats, execution plans, etc.) to the old environment this will basically just be a case of tuning the existing code from scratch.

    As Phil said, if you could post the execution plan (preferably the actual execution plan, if you're willing to wait the 30 minutes; it's a lot more helpful than the estimated plan), the code the job calls, along with the definition of the objects referenced (especially the view), then we might be able to give some pointers.

    Cheers!

  • Can you try to tweak the database level setting "Use legacy cardinality estimator" and then check the results ?

    In our environment it has helped at couple of places where the execution improved after changing this setting

Viewing 8 posts - 1 through 7 (of 7 total)

You must be logged in to reply to this topic. Login to reply