Using GROUP BY to collapse rows
Can I get the following with one select statement in SQL?
I have the following:
name value1 value2 value3 ---- ------ ------ ------ tom 1 tom 2 tom 3 chris 1 ray 6 ray 0
I want to get the following with one select:
tom,1,2,3 chris,,2, ray,6,,0
Is this possible and if yes, how?
This is a great example of how to "collapse" rows using the GROUP BY clause.
select name , max(value1) , max(value2) , max(value3) from daTable group by name
In SQL, the GROUP BY clause produces one result row for all distinct (combinations of) values of the column(s) mentioned in the GROUP BY clause.
In this particular example, the GROUP BY clause has only one column, name, so the query will produce one result row for every name value. It "collapses" all rows with the same name into one output result row.
The use of the MAX function in the other columns takes advantage of an important feature of aggregate functions, namely that they ignore NULLs. Each column value in the result row—remember, GROUP BY will produce one result row per name—will be the maximum value of all the values in the column, for that name, but ignoring NULLs.
As to the commas which you wanted in the result, you could use SQL string functions to produce them right in the query, but it's better to perform those types of transformations in your application code.
Dig Deeper on Oracle development languages
Related Q&A from Rudy Limeback
Using the SQL GROUP BY clause for counting combinations
Read SQL expert Rudy Limeback's advice for counting combinations in a table with SQL's GROUP BY clause Continue Reading
How to sort an SQL UNION query with special ORDER BY sequence
SQL expert Rudy Limeback explains how to sort an SQL UNION query using a special ORDERY BY sequence. Continue Reading
Using an SQL SELECT statement from a non-existing table
SQL expert Rudy Limeback explains how to formulate a query using an SQL SELECT statement from a non-existing table. Continue Reading