pivot data

i have this table in SQL:

column1,column2,column3
10,20,30

and i want to build a view that gives this output:

column1, 10, 60, 0.2222
column2, 20, 60, 0.3333
column3, 30, 60, 0.5555

last two column are: total of column1+2+3 and % on total

thanks in advanced
Amien90Asked:
Who is Participating?
I wear a lot of hats...

"The solutions and answers provided on Experts Exchange have been extremely helpful to me over the last few years. I wear a lot of hats - Developer, Database Administrator, Help Desk, etc., so I know a lot of things but not a lot about one thing. Experts Exchange gives me answers from people who do know a lot about one thing, in a easy to use platform." -Todd S.

ralmadaCommented:
Use UNPIVOT.
More reference on UNPIVOT here:
http://www.yafla.com/dennisforbes/UNPIVOT-Normalization-SQL-Server-2000-and-SQL-Server-2005/UNPIVOT-Normalization-SQL-Server-2000-and-SQL-Server-2005.html 

;with CTE as (
select Property, Value
(select * from yourtable) o
unpivot (Value for property in (column1, column2, column3)) p
)
select 	Property, 
	Value, 
	(select sum(Value) from CTE) as total, 
	Value / (select sum(Value) from CTE) 
from CTE

Open in new window

0
Amien90Author Commented:
end of #2 there need to be a , right?
getting following error:

incorrect syntax near the keyword 'UNPIVOT'
0
ralmadaCommented:
Oops, sorry Missed "FROM" actually
;with CTE as (
select Property, Value
from
(select * from yourtable) o
unpivot (Value for property in (column1, column2, column3)) p
)
select 	Property, 
	Value, 
	(select sum(Value) from CTE) as total, 
	Value / (select sum(Value) from CTE) 
from CTE

Open in new window

0
Newly released Acronis True Image 2019

In announcing the release of the 15th Anniversary Edition of Acronis True Image 2019, the company revealed that its artificial intelligence-based anti-ransomware technology – stopped more than 200,000 ransomware attacks on 150,000 customers last year.

Amien90Author Commented:
works .. two more issues:

1. last column has all 0 (zeros)
2. what if i want to cluster columns? so what if i want to add column4,5 and 6 .. but the percentage and total should only affect the clustered columns.
0
ralmadaCommented:
For issue 1 see attached.
Issue 2, I'm not following, can you elaborate? It would also help If you provide some sample data and expected result

;with CTE as (
select Property, Value
from
(select * from yourtable) o
unpivot (Value for property in (column1, column2, column3)) p
)
select 	Property, 
	Value, 
	(select sum(Value) from CTE) as total, 
	Value * 1.00 / (select sum(Value) from CTE) 
from CTE

Open in new window

0

Experts Exchange Solution brought to you by

Your issues matter to us.

Facing a tech roadblock? Get the help and guidance you need from experienced professionals who care. Ask your question anytime, anywhere, with no hassle.

Start your 7-day free trial
Amien90Author Commented:
column 1 till 3 is category I

column 4 till 6 is category II

value of total must only be over category for column 1 till 3 ..

when i add column 4 till 6 in the current query .. i will get the total of column 1-6

column1,column2,column3,column4,column5,column6
10,20,30,1,2,3

column1, 10, 60, 0.2222
column2, 20, 60, 0.3333
column3, 30, 60, 0.5555
column4,  1, 6, %
column4,  2, 6, %
column4,  3, 6, %
0
Amien90Author Commented:
typo ... triple column4, should be column4,column5 , column6 at the end..

output now, when i add column4,5,6

column1, 10, 66, 0.2222
column2, 20, 66, 0.3333
column3, 30, 66, 0.5555
column4,  1, 66, ....
column4,  2, 66, ...
column4,  3, 66, ....
0
ralmadaCommented:
So maybe something like this:
;with CTE as (
select Property, Value
from
(select * from yourtable) o
unpivot (Value for property in (column1, column2, column3)) p
)
select 	Property, 
	Value, 
	(select sum(Value) from CTE where property in ('column1', 'column2', 'column3')) as total, 
	CASE WHEN property in ('column1', 'column2', 'column3') then Value * 1.00 / (select sum(Value) from CTE where property in ('column1', 'column2', 'column3')) 
	else 0
	end as perc
from CTE

Open in new window

0
Amien90Author Commented:
yes .. but i also want to see the values of column4,5 and 6 ..

i'v changed: unpivot (Value for property in (column1, column2, column3, column4, column5, column6)) p

that gives me this result:

column1, 10, 66, 0.2222
column2, 20, 66, 0.3333
column3, 30, 66, 0.5555
column4,  1, 66, ....
column5,  2, 66, ...
column6,  3, 66, ....

which is almost good because i need

column1, 10, 60, 0.2222
column2, 20, 60, 0.3333
column3, 30, 60, 0.5555
column4,  1, 6, %
column5,  2, 6, %
column6,  3, 6, %

so for column1 till 3 the total column only need to SUM the colums1 till 3
total column on column 4 till 6 needs to be the SUM of column 4 till 6
0
Amien90Author Commented:
thanks for the swift replies btw
0
Amien90Author Commented:
(select sum(Value) from CTE) as total

perhaps add a where clause?

columns can be clustered by taking the first 5 chars of the column name .. ic property
0
Amien90Author Commented:

select  Property, 
        Value, 
        (select sum(Value) from CTE WHERE LEFT(t.property,5) = LEFT(property,5)) as total, 
        Value * 1.00 / (select sum(Value) from CTE WHERE LEFT(t.property,5) = LEFT(property,5)) as percentage
from CTE t

Open in new window

0
ralmadaCommented:
What about this?
;with CTE as (
select Property, Value, case when Property in ('column1', 'column2', 'column3') then 1 else 0 end as part
from
(select * from yourtable) o
unpivot (Value for property in (column1, column2, column3, column4, column5, column6)) p
)
select 	Property, 
	Value, 
	(select sum(Value) over(partition by part) from CTE) as total,
	Value * 1.00 / (select sum(Value) over(partition by part) from CTE) as percentage
 from CTE

Open in new window

0
ralmadaCommented:
Sorry I meant like this:
;with CTE as (
select Property, Value, case when property in ('column1', 'column2', 'column3') then 1 else 0 end as part
from
(select * from unpivo) o
unpivot (Value for property in (column1, column2, column3, column4, column5, column6)) p
)
select Property, Value, sum(Value) over (partition by part) as total, value * 1.0 / sum(Value) over (partition by part) as percentage from CTE
order by Property

Open in new window

0
It's more than this solution.Get answers and train to solve all your tech problems - anytime, anywhere.Try it for free Edge Out The Competitionfor your dream job with proven skills and certifications.Get started today Stand Outas the employee with proven skills.Start learning today for free Move Your Career Forwardwith certification training in the latest technologies.Start your trial today
Microsoft SQL Server 2005

From novice to tech pro — start learning today.