|
Using An Outer Join in a Query
From NeoWiki
Revision as of 02:06, 27 October 2007 (edit) Lorinda (Talk | contribs) (write article) ← Previous diff |
Revision as of 02:08, 27 October 2007 (edit) (undo) Lorinda (Talk | contribs) (add instruction to save the query) Next diff → |
||
Line 21: | Line 21: | ||
#Click {{Button|OK}} | #Click {{Button|OK}} | ||
#To test the results of our query, click on the {{Button|Run Query}} icon on the toolbar. (The data sources icon with the green arrow). | #To test the results of our query, click on the {{Button|Run Query}} icon on the toolbar. (The data sources icon with the green arrow). | ||
+ | #Save the Query by clicking on the {{Button|Save}} icon on the tool bar or pressing Command-S. You will be prompted to name the Query. I called mine '''Bird_Pictures_Locations'''. | ||
'''Note:''' This process works when only two tables are involved. Using a left or right join in a query combining more than two tables often provides undesired results, due to how Base turns the design view settings into SQL statements. Using outer joins with more than two tables can probably be done by creating the Query in SQL view (which requires knowledge of SQL) or by using the Query in a Query technique. This tutorial will hopefully be expanded to include directions for one or more of these techniques in the near future. | '''Note:''' This process works when only two tables are involved. Using a left or right join in a query combining more than two tables often provides undesired results, due to how Base turns the design view settings into SQL statements. Using outer joins with more than two tables can probably be done by creating the Query in SQL view (which requires knowledge of SQL) or by using the Query in a Query technique. This tutorial will hopefully be expanded to include directions for one or more of these techniques in the near future. |
Revision as of 02:08, 27 October 2007
By default, Base uses Inner Joins when you create a query that combines fields from two or more tables.. (Actually, Base usually uses WHERE statements rather than the INNER JOIN command in such circumstances, but Base labels the join type as an inner join, and the result is generally the same). An INNER JOIN selects only those records from each table that have corresponding records in the other tables used. When we created the All Sightings query, for example, the query returned only the AOU-ID fields that matched birds our fictional user has actually identified, not all the AOU_ID field values.
In some cases, however, you want to view all the records from one table, whether or not there are corresponding records in the other table. For example, not all of photos stored in the Bird_Pictures table correspond to a record in the Field_Trips table. But suppose we want to see a list of all the photos we've taken, but we also want to know where the photos were taken, if they were taken on a field trip. We can do this by using an OUTER JOIN.
- Click on the Queries icon in the left hand column of the main database document window.
- Click on the Create Table in Design View line in the Tasks name. The Query Design window opens, as will the Add Table or Query window.
- In the Add Table or Query window, add the Bird_Pictures and Field_Trips tables by clicking each one in turn and clicking Add.
- Close the Add Table or Query window.
- Add the following fields from the tables to the columns in the bottom section of the Query Design window: (See this tutorial if you aren't sure how to do so.)
- BirdPictured from the Bird_Pictures table
- DateTaken from the Bird_Pictures table
- Location from Field_Trips table.
- In the section of the 'Query Design window where the tables are shown, you should notice a line connecting PicFieldTripID in the Bird_Pictures table and FieldTrip_ID in the Field_Trips table. If there are no such lines connecting the tables, drag one of these two fields to the other field to create the line.
- Click on the connecting line so it turns blue.
- Double click on the selected line. The Join Properties window opens.
- In the Options section of the window, there is a Type drop-down that is currently set for Inner. Click on the drop-down to see that your choices also include Left join and Right join. A Left join pulls all the records from the field listed in the left column of the Fields Involved section, and only those in the right column that match those in the left. A right join does the reverse. Note that a detailed explanation, naming the tables and fields involved appears in the Options section as you change join types.
- Assuming that the PicFieldTrip_ID field is in the left-hand column, select Left join as the join type.
- Click OK
- To test the results of our query, click on the Run Query icon on the toolbar. (The data sources icon with the green arrow).
- Save the Query by clicking on the Save icon on the tool bar or pressing Command-S. You will be prompted to name the Query. I called mine Bird_Pictures_Locations.
Note: This process works when only two tables are involved. Using a left or right join in a query combining more than two tables often provides undesired results, due to how Base turns the design view settings into SQL statements. Using outer joins with more than two tables can probably be done by creating the Query in SQL view (which requires knowledge of SQL) or by using the Query in a Query technique. This tutorial will hopefully be expanded to include directions for one or more of these techniques in the near future.