Try this:

With t1 (order,SumDtlqty) as
(select order,sum(dtlqty)
from dtlfile
group by order)

select order, SumDtlQty, TotQty
from t1
join hdrfile h
on t1.order = h.order

-sjl


wrote in message news:mailman.1198.1365008652.7202.midrange-l@xxxxxxxxxxxx...

Perhaps something like:

With t1 as (select keyfld, sum(dtlqty) as dtlqty from dtlfile)
Select a.keyfld, a.totqty, b.dtlqty from hdr a, t1 b


Thanks,
Tommy Holden



From: "Stone, Joel" <Joel.Stone@xxxxxxxxxx>
To: "'Midrange Systems Technical Discussion'"
<midrange-l@xxxxxxxxxxxx>,
Date: 04/03/2013 11:56 AM
Subject: SQL: how to join header and detail records
Sent by: midrange-l-bounces@xxxxxxxxxxxx



I have an order header and detail file with one to many.

The order header has TOTQTY, which is the sum of all detail quantities.

The order detail has DTLQTY, which is one line's qty.



If I do a join of the two files and there is one HDR and five DTL records,
there will now be FIVE rows.

I want to compare the sum of the DTLQTY to the single TOTQTY value.

I can use SUM(DTLQTY) to provide the sum of the detail.

What is a good way to provide the TOTQTY? I don't want to use SUM(TOTQTY)
as this would give a result 5 times the correct value.

Is MAX(TOTQTY) what people generally use?

But that seems to be misleading since I am not really looking for the max
value, as all rows contain the same value for a header column.

Should I be grouping the detail PRIOR to the join, so there is only ONE
header value?

But it seems like the SQL stmt is SO much simpler if I do the join first.

Any ideas?

Thanks!



______________________________________________________________________
This outbound email has been scanned for all viruses by the MessageLabs
Skyscan service.
For more information please visit http://www.symanteccloud.com
______________________________________________________________________

As an Amazon Associate we earn from qualifying purchases.

This thread ...

Replies:

Follow On AppleNews
Return to Archive home page | Return to MIDRANGE.COM home page

This mailing list archive is Copyright 1997-2024 by midrange.com and David Gibbs as a compilation work. Use of the archive is restricted to research of a business or technical nature. Any other uses are prohibited. Full details are available on our policy page. If you have questions about this, please contact [javascript protected email address].

Operating expenses for this site are earned using the Amazon Associate program and Google Adsense.