Solved

Return only one record from a Grouped Table Join

Posted on 2014-09-15
2
183 Views
Last Modified: 2014-09-15
Hello

I have an orders table that has duplicate products on the same order.
I Need to ADD the duplicate Qtys together then return one of the Order Line ID's

I have Grouped the Table by the Order ID and the Stock Item but how do I get the Line ID of One of the Lines?

SELECT     SOL.SEQNO,SOL.HDR_SEQNO, SOL.STOCKCODE, SUM(SOL.ORD_QUANT)
FROM         dbo.SALESORD_LINES AS SOL
WHERE SOL.HDR_SEQNO = 205474
GROUP BY SOL.SEQNO,SOL.HDR_SEQNO,SOL.STOCKCODE

This Returns

SEQNO      HDR_SEQNO      STOCKCODE      ORDER_QTY
86616      205474      A101487              1
86617      205474      A101488       1
86618      205474      A101489       1
86619      205474      A103866       10
86620      205474      A103867       10
86621      205474      X100246       1
86622      205474      X100246       1

What I need is

SEQNO      HDR_SEQNO      STOCKCODE      ORDER_QTY
86616      205474      A101487              1
86617      205474      A101488       1
86618      205474      A101489       1
86619      205474      A103866       10
86620      205474      A103867       10
86621      205474      X100246       2

(The last two lines have the Order_qty added and one of the seqno records)

Note the "WHERE SOL.HDR_SEQNO = 205474" is only to reduce the records to one order for a sample - The code is to go in a view with thousands of orders
0
Comment
Question by:p-plater
2 Comments
 
LVL 24

Accepted Solution

by:
chaau earned 500 total points
ID: 40324446
It looks like you are interested in the MIN(SEQNO). Use this query:
SELECT     MIN(SOL.SEQNO) AS SEQNO, SOL.HDR_SEQNO, SOL.STOCKCODE, SUM(SOL.ORD_QUANT)
FROM         dbo.SALESORD_LINES AS SOL
WHERE SOL.HDR_SEQNO = 205474
GROUP BY SOL.HDR_SEQNO,SOL.STOCKCODE

Open in new window

0
 
LVL 65

Expert Comment

by:Jim Horn
ID: 40324458
Looks like chaau has directly answered your question, so I won't propose another answer, but as an aside if you want to read some articles related to what you're doing here, check out SQL Server GROUP BY Solutions and SQL Server Delete Duplicate Rows Solutions.
0

Featured Post

PRTG Network Monitor: Intuitive Network Monitoring

Network Monitoring is essential to ensure that computer systems and network devices are running. Use PRTG to monitor LANs, servers, websites, applications and devices, bandwidth, virtual environments, remote systems, IoT, and many more. PRTG is easy to set up & use.

Question has a verified solution.

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

Suggested Solutions

Title # Comments Views Activity
string fuctions 4 26
How To Convert Date Stored as Varchar as an MSSQL DATE Type Field In a VIEW 3 22
SQL Error - Query 6 25
performance query 4 22
Why is this different from all of the other step by step guides?  Because I make a living as a DBA and not as a writer and I lived through this experience. Defining the name: When I talk to people they say different names on this subject stuff l…
For both online and offline retail, the cross-channel business is the most recent pattern in the B2C trade space.
Via a live example, show how to extract insert data into a SQL Server database table using the Import/Export option and Bulk Insert.
Viewers will learn how to use the INSERT statement to insert data into their tables. It will also introduce the NULL statement, to show them what happens when no value is giving for any given column.

770 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