Want to win a PS4? Go Premium and enter to win our High-Tech Treats giveaway. Enter to Win

x
?
Solved

Calculate Median in Totals Query

Posted on 2006-06-19
15
Medium Priority
?
1,209 Views
Last Modified: 2009-01-02
Hi,

This sounds like a fairly hard question which I hope someone can help me on.  I have a "Totals" query that groups by certain fields and calculates the Avg.  The following is the SQL :

SELECT REGION, INDUSTRY, Avg(MEAN) AS AvgOfMEAN
FROM (tbl1 INNER JOIN tbl2 ON tbl1.DT = tbl2.DT) INNER JOIN tblRt ON tbl1.ID = tblRt.ID
WHERE (((REGION)="North America") AND ((INDUSTRY)="Transportation"))
GROUP BY REGION, INDUSTRY;

Now instead of Avg(Mean) I want the median of the means.  How can i do this?  Do I need to write a public function and reference it in the query?  That I have never done before.  Any help is appreciated.  Thanks

D
0
Comment
Question by:lebeau26
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 3
  • 3
  • 3
  • +3
15 Comments
 
LVL 65

Expert Comment

by:rockiroads
ID: 16935059
U want a avg of all?

u could try not grouping with the fields
did that work?

SELECT Avg(MEAN) AS AvgOfMEAN
FROM (tbl1 INNER JOIN tbl2 ON tbl1.DT = tbl2.DT) INNER JOIN tblRt ON tbl1.ID = tblRt.ID
WHERE (((REGION)="North America") AND ((INDUSTRY)="Transportation"))
0
 
LVL 65

Expert Comment

by:rockiroads
ID: 16935066
or perhaps

SELECT Avg(AvgOfMEAN)
FROM (SELECT REGION, INDUSTRY, Avg(MEAN) AS AvgOfMEAN
           FROM (tbl1 INNER JOIN tbl2 ON tbl1.DT = tbl2.DT) INNER JOIN tblRt ON tbl1.ID = tblRt.ID
           WHERE (((REGION)="North America") AND ((INDUSTRY)="Transportation"))
           GROUP BY REGION, INDUSTRY) AS qryAvg
0
 

Author Comment

by:lebeau26
ID: 16935160
Sorry, I basically want the Median of the means instead of the Avg of the means.  I do want to group by the region and industry though.

So basically it should look like:

Region       Industry        Median
America      Autos          100
England      Autos           50
America      Food           90
England       Food          10

Does this make more sense?
D
0
Concerto's Cloud Advisory Services

Want to avoid the missteps to gaining all the benefits of the cloud? Learn more about the different assessment options from our Cloud Advisory team.

 
LVL 93

Expert Comment

by:Patrick Matthews
ID: 16935241
Hi lebeau26,

You will need to use a UDF to get a median, unfortunately...

Regards,

Patrick
0
 

Author Comment

by:lebeau26
ID: 16935323
Ok, so how would I do this?  Again I have never used a UDF in a query before.  I usually just reference them in VBA.

Also, any ideas on how to code the median UDF ?

Thanks
D
0
 
LVL 44

Expert Comment

by:Leigh Purvis
ID: 16935754
Not sure if you'll be able to get a UDF for an aggregate function of course.
But there are many examples of calculating medians out there..
Something like
http://support.microsoft.com/?kbid=210581

Also if on a report - then just this might be useful.
http://support.microsoft.com/?kbid=209244

Lots of different takes on it - like
http://www.aspfaq.com/show.asp?id=2506

And one method from right here that might work for you within a query scenario
http://www.experts-exchange.com/Databases/MS_Access/Q_21631892.html
0
 

Author Comment

by:lebeau26
ID: 16935966
"Not sure if you'll be able to get a UDF for an aggregate function of course."

Really?  Thats not good because thats what I need.  I need it to group by region and then industry and then calculate the median in that.

Is anyone absolutely sure that median can't be done in an aggregate function?

D
0
 
LVL 58

Accepted Solution

by:
harfang earned 256 total points
ID: 16936066
Hello lebeau26

Here is one way to do it. It uses the same calling conventions as the other domain aggregate functions:

Function DMedian(Expr As String, Domain As String, _
    Optional Criteria = Null, _
    Optional Delim As String = ", ")
'
' Similar to DAvg(), but returning the median
'
    DMedian = Null
    With New ADODB.Recordset
        .Open "Select " & Expr & " From " & Domain _
            & " Where " + Criteria & " Order By " & Expr _
        , CurrentProject.Connection, adOpenStatic, adLockReadOnly
        If Not .EOF Then
            .MoveLast
            If .RecordCount Mod 2 Then
                .AbsolutePosition = .RecordCount \ 2 + 1
                DMedian = .Fields(0)
            Else
                .AbsolutePosition = .RecordCount \ 2
                DMedian = .Fields(0) / 2
                .MoveNext
                DMedian = DMedian + .Fields(0) / 2
            End If
        End If
    End With
   
End Function

(°v°)
0
 
LVL 44

Assisted Solution

by:Leigh Purvis
Leigh Purvis earned 248 total points
ID: 16936112
Well in Group By you could happily let a UDF do the work - just create and pass in the relevant parameters to calculate across only certain groupings.
An ammendment of Markus or any previous code should be able to do that easily.
0
 
LVL 58

Expert Comment

by:harfang
ID: 16936124
This time I should have refreshed. Many things can happen during two phone calls...

I like the SQL solutions in one of Leigh's links, but I'm not quite sure they work in Access as is. Top 1 is not guaranteed to return a single record, which is a problem for subqueries...

(°v°)
0
 
LVL 58

Expert Comment

by:harfang
ID: 16936297
One more thing:

There are two types of aggregate functions in Access. SQL aggregate functions like Avg(), First(), etc., which cannot be user-defined, and regular VB "domain aggregate" functions like DAvg(), DLookup(), of which you can create new ones.

Note that other major variants of SQL allow the creation of new aggregate functions, but not JetSQL, as far as I know.

If your case, use DMedian( "AvgOfMEAN", "<your query name>" )

(°v°)
0
 
LVL 65

Assisted Solution

by:rockiroads
rockiroads earned 248 total points
ID: 16937828
I found this, if this is any help 4 u

http://experts.about.com/q/Using-MS-Access-1440/Calculate-Median.htm

it is vba code Im afraid

0
 
LVL 74

Assisted Solution

by:Jeffrey Coachman
Jeffrey Coachman earned 248 total points
ID: 17038651
lebeau26,

If you like, you can try to use Excel's "Median" function in Access:

http://www.fabalou.com/Access/Queries/excel_functions.asp
http://support.microsoft.com/?kbid=198571

Hope this helps as well
0

Featured Post

Free Tool: ZipGrep

ZipGrep is a utility that can list and search zip (.war, .ear, .jar, etc) archives for text patterns, without the need to extract the archive's contents.

One of a set of tools we're offering as a way to say thank you for being a part of the community.

Question has a verified solution.

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

You need to know the location of the Office templates folder, so that when you create new templates, they are saved to that location, and thus are available for selection when creating new documents.  The steps to find the Templates folder path are …
This article shows how to get a list of available printers for display in a drop-down list, and then to use the selected printer to print an Access report or a Word document filled with Access data, using different syntax as needed for working with …
Basics of query design. Shows you how to construct a simple query by adding tables, perform joins, defining output columns, perform sorting, and apply criteria.
With Microsoft Access, learn how to start a database in different ways and produce different start-up actions allowing you to use a single database to perform multiple tasks. Specify a start-up form through options: Specify an Autoexec macro: Us…

618 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