SELECT Statement
This MariaDB tutorial explains how to use the MariaDB SELECT statement with syntax and examples.
Description
The MariaDB SELECT statement is used to retrieve records from one or more tables in MariaDB.
Syntax
In its simplest form, the syntax for the SELECT statement in MariaDB is:
SELECT expressions
FROM tables
[WHERE conditions];
However, the full syntax for the MariaDB SELECT statement is:
SELECT [ ALL | DISTINCT ]
expressions
FROM tables
[WHERE conditions]
[GROUP BY expressions]
[HAVING condition]
[ORDER BY expression [ ASC | DESC ]]
[LIMIT [offset_value] number_rows | LIMIT number_rows OFFSET offset_value]
[PROCEDURE procedure_name]
[INTO [ OUTFILE 'file_name' options
| DUMPFILE 'file_name'
| @variable1, @variable2, ... @variable_n ]
[FOR UPDATE | LOCK IN SHARE MODE];
Parameters or Arguments
ALL
Optional. ALL returns all matching rows.
DISTINCT
Optional. DISTINCT removes duplicates from the result set.
expressions
The columns or calculations that you wish to retrieve.
tables
The tables that you wish to retrieve records from. There must be at least one table listed in the FROM clause.
WHERE conditions
Optional. The conditions that must be met for the records to be selected.
GROUP BY expressions
Optional. It collects data across multiple records and groups the results by one or more columns.
HAVING condition
Optional. It is used in combination with the GROUP BY to restrict the groups of returned rows to only those whose the condition is TRUE.
ORDER BY expression
Optional. It is used to sort the records in your result set.
LIMIT
Optional. If LIMIT is provided, it controls the maximum number of records to retrieve. At most, the number of records specified by number_rows will be returned in the result set. The first row returned by LIMIT will be determined by offset_value.
PROCEDURE
Optional. If provided, procedure_name is the name of the procedure that should process the data in the result set.
INTO
Optional. If provided, it allows you to write the result set to either a file or variable.
Value |
Explanation |
INTO OUTFILE 'filename' options |
Writes the result set to a file called filename on the server host. For options, you can specify: |
INTO DUMPFILE 'filename' |
Writes one row of the result set to a file called filename on the server host. With this method, there is no column termination, no line termination, or escape processing. |
INTO @variable1, @variable2, ... @variable_n |
Writes the result set to one or more variables, as specified by @variable1, @variable2, ... @variable_n |
FOR UPDATE
Optional. Records affected by the query are write-locked until the transaction has completed
LOCK IN SHARE MODE
Optional. Records affected by the query can be used by other transactions but can not be updated or deleted by those other transactions.
Example - Select all columns from one table
Let's look at how to use a MariaDB SELECT query to select all columns from a table.
For example:
SELECT *
FROM sites
WHERE site_name = 'Fastread.aitechtonic.com'
ORDER BY site_id ASC;
In this SELECT example, we've used * to signify that we wish to select all fields from the sites table where the site_name is 'Fastread.aitechtonic.com'. The results are sorted by site_id in ascending order.
Example - Select individual columns from one table
When using the SELECT statement in MariaDB, you do not have to select all columns from the table. Instead, you can select the individual columns that you would like to return in your result set.
For example:
SELECT site_id, site_name
FROM sites
WHERE site_id < 32
ORDER BY site_id ASC, site_name DESC;
This MariaDB SELECT example would return only the site_id and site_name fields from the sites table where the site_id is less than 32. The results are sorted by site_id in ascending order and then site_name in descending order.
Example - Select columns from multiple tables
The SELECT statement in MariaDB can also select columns from more than one table.
For example:
SELECT pages.page_id, sites.site_name
FROM sites
INNER JOIN pages
ON sites.site_id = pages.site_id
WHERE sites.site_name = 'Fastread.aitechtonic.com'
ORDER BY pages.page_id;
This SELECT statement example joins two tables to return a result set that includes the page_id and site_name fields. The results of the SELECT statement are filtered where the site_name is 'Fastread.aitechtonic.com' and the site_id value matches in both the sites and pages table. The results are sorted by page_id in ascending order.
Example - write to a file
Finally, let's look at how to use the MariaDB SELECT statement to write the results of the SELECT statement to a file.
For example:
SELECT site_id, site_name
FROM sites
WHERE site_name = 'Fastread.aitechtonic.com'
ORDER BY site_id DESC
INTO OUTFILE 'results.txt'
FIELDS TERMINATED BY ',' OPTIONALLY ENCLOSED BY '"'
LINES TERMINATED BY '\n';
This MariaDB SELECT example would return only the site_id and site_name fields from the sites table where the site_name is 'Fastread.aitechtonic.com'. The results would be sorted by site_id in descending order and written to a file called results.txt.