Learning Mysql



Download 4.24 Mb.
View original pdf
Page206/366
Date04.08.2023
Size4.24 Mb.
#61806
1   ...   202   203   204   205   206   207   208   209   ...   366
Learning MySQL
The DISTINCT Clause
To begin our discussion on aggregate functions, we’ll focus on the
DISTINCT
clause.
This isn’t really an aggregate function, but more of a post-processing filter that allows
228 | Chapter 7:
Advanced Querying

you to remove duplicates. We’ve added it into this section because, like aggregate functions, it’s concerned with picking examples from the output of a query, rather than processing individual rows.
An example is the best way to understand DISTINCT. Consider this query:
mysql> SELECT DISTINCT artist_name FROM
-> artist INNER JOIN album USING (artist_id);
+---------------------------+
| artist_name |
+---------------------------+
| New Order |
| Nick Cave & The Bad Seeds |
| Miles Davis |
| The Rolling Stones |
| The Stone Roses |
| Kylie Minogue |
+---------------------------+
6 rows inset sec)
The query finds artists who have made albums—by joining together artist and album with an INNER JOIN
clause—and reports one example of each artist. You can see that we have six artists in our database for whom we own albums. If you remove the
DISTINCT
clause, you get one row of output for each album we own:
mysql> SELECT artist_name FROM
-> artist INNER JOIN album USING (artist_id);
+---------------------------+
| artist_name |
+---------------------------+
| New Order |
| New Order |
| New Order |
| New Order |
| New Order |
| New Order |
| New Order |
| Nick Cave & The Bad Seeds |
| Miles Davis |
| Miles Davis |
| The Rolling Stones |
| The Stone Roses |
| Kylie Minogue |
+---------------------------+
13 rows inset sec)
So, the
DISTINCT
clause helps get a summary.
The
DISTINCT
clause applies to the query output and removes rows that have identical values in the columns selected for output in the query. If you rephrase the previous query to output both artist_name and album_name
(but otherwise don’t change the
JOIN
clause and still use DISTINCT, you’ll get all 13 rows in the output:
mysql> SELECT DISTINCT artist_name, album_name FROM

Download 4.24 Mb.

Share with your friends:
1   ...   202   203   204   205   206   207   208   209   ...   366




The database is protected by copyright ©ininet.org 2025
send message

    Main page