Jump to content

SQL summarising


Recommended Posts

Lads,

 

I'm trying to run the following query, but it's taking ages. Any idea how I can summarise it to speed it up any? 

 

Select
Td.Branch,
Td.Cust_Code, td.prod_dept, td.supplier_code,s.supplier_name,
REPLACE(CONVERT(VARCHAR,CONVERT(MONEY,cast(sum(case when record_type in (7,16) and *****.dbo.ftnGetGoLocalTopScheme(td.branch,td.cust_code) like 'g%' then total_value *-1
         when record_type not in (7,16) and *****.dbo.ftnGetGoLocalTopScheme(td.branch,td.cust_code) like 'g%' then total_value
    else 0.00 end)as decimal(10,2))),1),'.00','.00') as [GL Spend]
From Transaction_Details as Td
left outer join dbo.supplier as s on td.supplier_code=s.supplier_code
Where Td.Branch >0 and Td.Date_Transaction Between '2015-06-24' AND '2016-04-29 23:59'

Group By Td.Branch, Td.Cust_Code, td.prod_dept, td.supplier_code, s.supplier_name

 

 

Cheers
 

Link to post
Share on other sites
  • 2 weeks later...

@The Fishwhen you say ages for how many records are we talking here? Not going to fix your sql but have you got indexes on and do you need to use like and wildcards in that manner or at all?

run your query with show execution plan to point out where your bottlenecks are

 

like something% is basically the worst version of that and less likely to use or attempt to use any indexing 

 

(that's me being kind)

Link to post
Share on other sites
  • 2 years later...

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now
×
×
  • Create New...