Solved

How can  I sum a column as an expression?

Posted on 2010-11-15
4
920 Views
Last Modified: 2012-05-10
In my VarChar Column,  'ZZ',  I have 3  possibilities with a total of 134 rows :

Possibilities
1.  aaaa
2.  bbbb
3.  cccc

I need to create a table to show a total of each of these possibilities that are listed.

Example:
aaaa    bbbb    cccc
 53         47        34        TOTAL
`
Please provide an expression that I can use to obtain each of  the 3  totals.
0
Comment
Question by:rhservan
  • 2
4 Comments
 
LVL 13

Expert Comment

by:sameer2010
ID: 34141798
Try this
select 

sum(case when possibility = 'aaa' then 1 else 0 end) possaaa,

sum(case when possibility = 'bbb' then 1 else 0 end) possbbb,

sum(case when possibility = 'ccc' then 1 else 0 end) possccc,

sum(case when possibility = 'aaa' then 1 else 0 end) + sum(case when possibility = 'bbb' then 1 else 0 end) + sum(case when possibility = 'ccc' then 1 else 0 end) posstotal

from your_table

Open in new window

0
 

Author Comment

by:rhservan
ID: 34142232
Sameer,

There seems to be some missing information on line five at the end.
0
 
LVL 21

Assisted Solution

by:Alfred1
Alfred1 earned 250 total points
ID: 34142304
Try something like this.
SELECT *

FROM (

SELECT (CASE ZZ

           WHEN 'aaaa' THEN 'aaaa'

           WHEN 'bbbb' THEN 'bbbb'

           WHEN 'cccc' THEN 'cccc'

        END) As [Poss],

        (COUNT((CASE ZZ

           WHEN 'aaaa' THEN 'aaaa'

           WHEN 'bbbb' THEN 'bbbb'

           WHEN 'cccc' THEN 'cccc'

        END)) As [SubTotal]

FROM YOURTABLE

GROUP BY ZZ

) TableZZ

PIVOT (

SUM(SubTotal)

FOR [Poss] IN (

[aaaa],[bbbb],[cccc]

)

) PivotTable

Open in new window

0
 
LVL 13

Accepted Solution

by:
sameer2010 earned 250 total points
ID: 34160681
Are you getting any error? What is the error you are getting?
The first 4 lines select the count of non-blank possiblities and 5th row calculates the sum for all non-blank rows. If you do not need total for all possibilities, you can drop that row. So, the query would become
select 

sum(case when possibility = 'aaa' then 1 else 0 end) possaaa,

sum(case when possibility = 'bbb' then 1 else 0 end) possbbb,

sum(case when possibility = 'ccc' then 1 else 0 end) possccc

from your_table

Open in new window

0

Featured Post

Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Steps to solve SSRS SQL 2008 R2 User Access Control (UAC) Permission Error With the introduction of SQL Server 2008 R2 and Vista (Windows 7 as well) came new enhanced security features. One of the features included was User Access Control (UAC) t…
Occasionally there is a need to clean table columns, especially if you have inherited legacy data. There are obviously many ways to accomplish that, including elaborate UPDATE queries with anywhere from one to numerous REPLACE functions (even within…
In this video I am going to show you how to back up and restore Office 365 mailboxes using CodeTwo Backup for Office 365. Learn more about the tool used in this video here: http://www.codetwo.com/backup-for-office-365/ (http://www.codetwo.com/ba…
Learn how to create flexible layouts using relative units in CSS.  New relative units added in CSS3 include vw(viewports width), vh(viewports height), vmin(minimum of viewports height and width), and vmax (maximum of viewports height and width).

896 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

14 Experts available now in Live!

Get 1:1 Help Now