Kexi/Handbook/Building Simple Databases/Designing Database Queries: Difference between revisions
(Marked this version for translation) |
No edit summary |
||
(5 intermediate revisions by 3 users not shown) | |||
Line 4: | Line 4: | ||
<!--T:2--> | <!--T:2--> | ||
The primary purpose of a database is to store data and then provide for the efficient extraction of the information that you are looking for. The '''Kexi''' database allows you to utilise specific and powerful search criteria returning results rapidly even for large data sets. However to be able to run effective queries on your database, you need to learn how to tell the database what you are looking for. | |||
<!--T:3--> | <!--T:3--> | ||
Line 10: | Line 10: | ||
<!--T:4--> | <!--T:4--> | ||
To see how queries work in practice | To see how queries work in practice we will create a contacts query joining data from two tables: '''''Persons''''' and '''''Phones''''' (designed [[Special:MyLanguage/Kexi/Handbook/Building Simple Databases/Designing Database Tables|here]] and filled with data [[Special:MyLanguage/Kexi/Handbook/Building Simple Databases/Entering Data Into Tables|here]]). | ||
<!--T:5--> | <!--T:5--> | ||
# Create a new empty query by selecting <menuchoice | # Create a new empty query by selecting <menuchoice>Query</menuchoice> from the toolbar. The design window will appear. The window is split into two areas: query relationships at the top and query columns below. </translate> | ||
<translate> | <translate> | ||
<!--T:8--> | <!--T:8--> | ||
# Select the table | # Select the table '''''Persons''''' in the drop down list <menuchoice>Table:</menuchoice> located at the top of the window and click the <menuchoice>Insert</menuchoice> button. A graphical representation of the table will appear in the relations area. Do the same for the '''''Phones''''' table to insert it too. </translate> | ||
<translate> | <translate> | ||
<!--T:9--> | <!--T:9--> | ||
# Add query relationship using mouse drag & drop technique: click the field id in the | # Add query relationship using mouse drag & drop technique: click the field '''''id''''' in the '''''persons''''' table, drag it and drop into the '''''person''''' field of the '''''phone''''' table. This will join both fields by creating a new relationship. </translate> | ||
# Double-click the name field in the | <!--FIXME Why have some field/table names in this sentence a replaceable markup, others not? Why have the same field/table names in this document different capitalisation? This happens at several other parts of this documentation as well COMMENT: when the replacables refer to captions they should probably be capitalized, but when they are names they should be all lower case--> | ||
<translate> | |||
<!--T:12--> | |||
# Double-click the '''''name''''' field in the '''''Persons''''' table, to add the field as a query column. In a similar way, add '''''surname''''', '''''street''''', '''''house_number''''', '''''city''''' fields from the '''''Persons''''' table and phone from the '''''Phones''''' table. </translate> | |||
<translate> | <translate> | ||
<!--T:10--> | <!--T:10--> | ||
# Query design is now ready for testing. Click the <menuchoice> | # Query design is now ready for testing. Click the <menuchoice>Data</menuchoice> button on the toolbar, to switch from design to viewing the data provided as query results.</translate> | ||
<translate> | <translate> | ||
<!--T:11--> | <!--T:11--> | ||
# Save the query design for later use by clicking the | # Save the query design for later use by clicking the <menuchoice>Save</menuchoice> button on the toolbar. Because the query design has not been saved yet, you will be asked to specify a name for it. Enter '''''Contacts''''' text in the caption field and click the <menuchoice>OK</menuchoice> button. | ||
<!--T:6--> | <!--T:6--> |
Latest revision as of 19:15, 15 May 2015
Designing Database Queries
The primary purpose of a database is to store data and then provide for the efficient extraction of the information that you are looking for. The Kexi database allows you to utilise specific and powerful search criteria returning results rapidly even for large data sets. However to be able to run effective queries on your database, you need to learn how to tell the database what you are looking for.
With database queries you can limit data coming from a table to a predefined set of rows and columns as well as dynamically join data coming from multiple tables.
To see how queries work in practice we will create a contacts query joining data from two tables: Persons and Phones (designed here and filled with data here).
- Create a new empty query by selecting from the toolbar. The design window will appear. The window is split into two areas: query relationships at the top and query columns below.
- Select the table Persons in the drop down list located at the top of the window and click the button. A graphical representation of the table will appear in the relations area. Do the same for the Phones table to insert it too.
- Add query relationship using mouse drag & drop technique: click the field id in the persons table, drag it and drop into the person field of the phone table. This will join both fields by creating a new relationship.
- Double-click the name field in the Persons table, to add the field as a query column. In a similar way, add surname, street, house_number, city fields from the Persons table and phone from the Phones table.
- Query design is now ready for testing. Click the button on the toolbar, to switch from design to viewing the data provided as query results.
- Save the query design for later use by clicking the button on the toolbar. Because the query design has not been saved yet, you will be asked to specify a name for it. Enter Contacts text in the caption field and click the button.