[Webinar] Streamline your web hosting managementRegister Today

x
  • Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 107
  • Last Modified:

Using field values to generate columns - oracle query

Using the following query, how could I take any field values from the homeroom column and use those values to create new columns based on the number of results (see examples below)?  I've used 3 homerooms in my example but in some cases there could be up to 10 per grade. Thanks!!

SELECT
grade_level as "Grade Level",
home_room,
COUNT(*) "Total Enrolled"
from students
where 
enroll_status=0 
AND schoolid IN (3)
group by home_room, grade_level

Open in new window


current results
Grade Level, HOME_ROOM, Total Enrolled
3, homeroom1, 17
3, homeroom2, 14
4, homeroom3, 15
5, homeroom4, 16
5, homeroom5, 18
5, homeroom6, 19

Open in new window


desired results
Grade Level, 1st Result, 2nd Result, 3rd Result, Total Enrolled
3, 17, 14, , 31
4, 15, , , 15
5, 16, 18, 19, 53

Open in new window

0
Basssque
Asked:
Basssque
  • 3
  • 2
1 Solution
 
sdstuberCommented:
  SELECT grade_level,
         MAX(CASE WHEN rn = 1 THEN cnt END) first_result,
         MAX(CASE WHEN rn = 2 THEN cnt END) second_result,
         MAX(CASE WHEN rn = 3 THEN cnt END) third_result,
         SUM(cnt)                         total_enrolled
    FROM (SELECT q.*, ROW_NUMBER() OVER(PARTITION BY grade_level ORDER BY home_room) rn
            FROM (  SELECT grade_level, home_room, COUNT(*) cnt
                      FROM students
                     WHERE enroll_status = 0 AND schoolid IN (3)
                  GROUP BY home_room, grade_level) q)
GROUP BY grade_level
ORDER BY grade_level;

Open in new window

0
 
QlemoDeveloperCommented:
... and should you wonder: There is no way to have a dynamic number of columns. You always need to code for the max number of columns, even if you use the Pivot syntax not shown yet.
0
 
sdstuberCommented:
a better version of what I posted above,
the first uses your original query this skips the extra layer of aggregation.

  SELECT grade_level,
         NULLIF(COUNT(CASE WHEN rn = 1 THEN 1 END), 0) first_result,
         NULLIF(COUNT(CASE WHEN rn = 2 THEN 1 END), 0) second_result,
         NULLIF(COUNT(CASE WHEN rn = 3 THEN 1 END), 0) third_result,
         COUNT(*)                                    total_enrolled
    FROM (SELECT s.*, DENSE_RANK() OVER(PARTITION BY grade_level ORDER BY home_room) rn
            FROM students s)
GROUP BY grade_level
ORDER BY grade_level;

Open in new window


and qlemo is correct, there isn't a way to create a dynamic list of columns using only sql
0
The new generation of project management tools

With monday.com’s project management tool, you can see what everyone on your team is working in a single glance. Its intuitive dashboards are customizable, so you can create systems that work for you.

 
BasssqueAuthor Commented:
sdstuber,

The first query worked
The second query didn't return any results except in the total column.
Is there a way to prevent columns from being rendered if there are no results in a column?  Thanks!!
0
 
sdstuberCommented:
>>> Is there a way to prevent columns from being rendered

No, that's another form of creating a dynamic result set which is not possible within SQL.
The reason is - a SQL statement must know the columns it is going to return when it is parsed (i.e. before it executes.)  So, trying to base the columns on the results of the query will never work using SQL alone.

The only way to do what you want is to use a reporting tool that can evaluate the result set and only display columns as needed,  or use pl/sql or some other language to pre-evaluate the results (generally by executing some variation of the query first) then constructing a specific sql query to return exactly what you want.  Again, this is not really a sql solution then.


>>> The second query didn't return any results except in the total column.

using what sample data?
It tested both queries using your sample data and they both worked.
0
 
BasssqueAuthor Commented:
Thank you again for your time!
0

Featured Post

Never miss a deadline with monday.com

The revolutionary project management tool is here!   Plan visually with a single glance and make sure your projects get done.

  • 3
  • 2
Tackle projects and never again get stuck behind a technical roadblock.
Join Now