|
Using the Group Function in a Query
From NeoWiki
This article is part of the To Base and Back Again tutorial series.
Avid birders keep a life list. A life list is a list of bird species the birder has identified. To be an adequate tool for birders, our database needs to include a means for creating a life list. We took a step in that direction when we created the All Sightings query. If you have entered the test data provided in the article Creating A Data Entry Form With A Subform, however, you will notice that certain bird species (e.g. the Tufted Timouse) appear twice in the list. For a serious birder who makes regular field trips, there would quickly be even more entries for each species in this list. We need to construct a query that will list each bird species only once.
Creating the Query
- In the main database document, click on the Queries icon in the left hand column.
- Click on the Create Query in Design View icon in the Tasks section. The Query Design window opens and the Add Table or Query window opens.
- In the Add Table of Query window, click on the Queries radio button
- Select the Sightings List query and click Add
- Close the Add Table of Query window by clicking Close
- Adjust the Sightings mini-window as necessary to see the full list of fields.
- Add the following fields to the Query, in the order given:
- AOU_ID
- Bird_Name
- Date
- Date (you will have two columns headed with the Date field)
- In the Function row of the AOU_ID and Bird_Name columns, select Group from the dropdown. (You need to click in the cell before the dropdown appears.)
- In the Sort row, select ascending under the AOU_ID column.
- In the Function row, under the first Date column, select Minimum from the dropdown.
- In the Alias row, under the first Date column, type DateFirstSeen
- In the Function row, under the second Date column, select Count from the dropdown.
- In the Alias row, under the second Date column, type SightingsCount
- Click the Run Query button on the toolbar. (It is the data sources icon with a green arrow pointing down). After a pause, you should see the query results.
- The rows will be sorted by AOU_ID order, and there will only be one entry for each bird species.
- Note that the DateFirstSeen column will contain integers, not dates. There are three ways to deal with this:
- Control-click or right-click on the DateFirstSeen column of the query results and choose Column Format... from the contextual menu. Set the Category to Date and choose the Desired Format. Click OK. (This works even if the Query hasn't been opened in design mode)
- Use the CAST function as described below
- Correct the issue only in forms using the query by using a date or formatted control for the DateFirstSeen field. This is left as an exercise for the student.
- The SightingsCount column indicates how many times a given bird has been identified.
- Save your query by clicking on the Save button on the toolbar or hitting Command-S.
- In the window that appears, give your query the name Life_List
- Click OK
Other Notes
- The Maximum, Average, and Sum functions work similarly. They all require you to group your data first, as we have done above.
- You cannot add fields to a Group query that are not assigned a function.
This article in other languages: Français