Query Help regarding top 10 customer

  • I am newbie to  SQL programming. wanted to get top 10 customer for the totaldue. tried to build the dynamically could not succeed. then did some trick with hard coded values here is my query. please let me know how to go about it

     

    SELECT OrderYear,CustomerID,TotalDue FROM (

    SELECT * FROM

    (

    SELECT YEAR(OrderDate) AS OrderYear,Customerid,sum(TotalDue) as TotalDue,

    ROW_NUMBER() OVER(ORDER BY SUM(TOTALDUE) DESC) EN

    FROM Sales.SalesOrderHeader

    where YEAR(OrderDate)='2012'

    group by YEAR(OrderDate),CustomerID

    ) A WHERE EN<=10

    UNION ALL

    SELECT * FROM

    (

    SELECT YEAR(OrderDate) AS OrderYear,Customerid,sum(TotalDue) as TotalDue,

    ROW_NUMBER() OVER(ORDER BY SUM(TOTALDUE) DESC) EN

    FROM Sales.SalesOrderHeader

    where YEAR(OrderDate)='2013'

    group by YEAR(OrderDate),CustomerID

    ) A WHERE EN<=10

    UNION ALL

    SELECT * FROM

    (

    SELECT YEAR(OrderDate) AS OrderYear,Customerid,sum(TotalDue) as TotalDue,

    ROW_NUMBER() OVER(ORDER BY SUM(TOTALDUE) DESC) EN

    FROM Sales.SalesOrderHeader

    where YEAR(OrderDate)='2014'

    group by YEAR(OrderDate),CustomerID

    ) A WHERE EN<=10

    UNION ALL

    SELECT * FROM

    (

    SELECT YEAR(OrderDate) AS OrderYear,Customerid,sum(TotalDue) as TotalDue,

    ROW_NUMBER() OVER(ORDER BY SUM(TOTALDUE) DESC) EN

    FROM Sales.SalesOrderHeader

    where YEAR(OrderDate)='2015'

    group by YEAR(OrderDate),CustomerID

    ) A WHERE EN<=10

    ) AS A

    order by OrderYear ASC,TotalDue DESC

  • What about simplifying this a bit and just use the TOP command. All you need is the ORDER BY. You don't have to go into all that row number stuff.

    "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

  • Please provide some T-SQL statements tabledefinition , the sampledata and expected results based on that sampledata.

    So we can copy paste & execute it in ssms without typing.

  • You want the top 10 for each year, or just the top 10 for eternity?

    (I ask, because your sample code references YEAR(OrderDate) all over the place, though you do not mention this in your requirement.)

    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

  • sorry my bad. I want top 1o maximum total due  based on the customer id  based on the year

  • I think you just need to add a partition to your ROW_NUMBER().

    SELECT * FROM
    (
    SELECT YEAR(OrderDate) AS OrderYear,
    Customerid,
    sum(TotalDue) as TotalDue,
    ROW_NUMBER() OVER(PARTITION BY YEAR(OrderDate) ORDER BY SUM(TOTALDUE) DESC) EN
    FROM Sales.SalesOrderHeader
    group by YEAR(OrderDate),CustomerID
    ) A WHERE EN<=10

    Drew

    Edited to add Customerid to the partition.

    Edited to remove Customerid from the partition.  This is where having sample data would really help.

    • This reply was modified 1 year, 2 months ago by  drew.allen.
    • This reply was modified 1 year, 2 months ago by  drew.allen.

    J. Drew Allen
    Business Intelligence Analyst
    Philadelphia, PA

  • praveensc2021 wrote:

    sorry my bad. I want top 1o maximum total due  based on the customer id  based on the year

    Difficult to write this query without some sample DDL and data.

    But to do it all in one query, you will need to PARTITION your row_number() by year.

    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

  • Thank you drew and phill.

  • This was removed by the editor as SPAM

  • This was removed by the editor as SPAM

  • This was removed by the editor as SPAM

Viewing 11 posts - 1 through 10 (of 10 total)

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